**在本地安装虚拟机请务必给虚拟机分配足够内存!!!,**否则服务可能会在启动中挂掉
分配4G内存我这边是够的,具体需要分配多少内存请根据实际情况加上微服务数量来分配内存
docker中常用的命令
docker images #查看镜像 docker ps #查看正在运行的容器 docker ps -a #查看所有容器(包括运行和停止)docker-compose命令
#以下命令需安装完docker-compose后方可执行查看效果 docker-compose logs #查看启动服务所打印的日志 docker-compose logs -f #跟踪启动服务的日志打印 docker-compose up -d # 后台启动端口侦听
netstat -luntp #查看所有服务启动后端口是否被侦听*这个很重要*Docker 环境安装
安装所需的软件包
yum install -y yum-utils
设置存储库
# 阿里云地址(国内地址,相对更快)
yum-config-manager
--add-repo
http://mirrors.aliyun.com/docker-ce/linux/centos/docker-ce.repo
安装Docker引擎
yum install docker-ce docker-ce-cli containerd.io
安装完成后,运行下面的命令,验证是否安装成功。
docker version # 查看Docker版本信息 systemctl start docker # 启动 docker 服务: systemctl stop docker # 停止 docker 服务: systemctl status docker # 查看 docker 服务状态 systemctl restart docker # 重启 docker 服务配置镜像
使用配置文件/etc/docker/daemon.json(没有时新建该文件)
vim /etc/docker/daemon.json
# 添加如下内容,可以自己替换。默认地址是我的创建的
{
"registry-mirrors": ["https://mr63yffu.mirror.aliyuncs.com"]
}
重启Docker Daemon即可
systemctl daemon-reload应用部署 Nacos
拉取官方nacos镜像
目前若依微服务最新版本需要安装的是2.0.4版本,如需更改请根据实际情况修改拉取的版本号
docker pull nacos/nacos-server:v2.0.4
启动nacos 需要暴露8848 9848 9849 端口
docker run --env MODE=standalone --name nacos -d -p 8848:8848 -p 9848:9848 -p 9849:9849 nacos/nacos-server:v2.0.4
MODE=standalone表示单机启动
Nginx拉取官方nginx镜像,默认拉取最新版本
docker pull nginx
创建Nginx容器。
docker run -di --name nginx -p 80:80 nginx
将容器内的配置文件拷贝到指定目录(请先提前创建好目录)。
# 创建目录 mkdir -p /home/ruoyi/nginx # 将容器内的配置文件拷贝到指定目录 docker cp nginx:/etc/nginx /home/ruoyi/nginx/conf
终止并删除容器 需要执行
docker stop nginx docker rm nginx
创建Nginx容器,并将容器中的/etc/nginx目录和宿主机的/home/ruoyi/nginx/conf目录进行挂载。
docker run -di --name nginx -p 80:80 -v /home/ruoyi/nginx/conf:/etc/nginx nginxMysql
拉取官方mysql8.0镜像
docker pull mysql:8.0
在本地创建mysql的映射目录
mkdir -p /home/mysql/data /home/mysql/logs /home/mysql/conf
创建容器,将数据、日志、配置文件映射到本机
#此处的password为即将设置的数据库密码建议修改成为自己的密码 docker run -p 3306:3306 --name mysql -v /home/mysql/conf:/etc/mysql/conf.d -v /home/mysql/logs:/logs -v /home/mysql/data:/var/lib/mysql -e MYSQL_ROOT_PASSWORD=root -d mysql:8.0
进入容器/执行命令:docker exec -it mysql /bin/bash
更改数据库密码
docker exec -it mysql /bin/bash #未挂载镜像时进入MySQL方式 //docker exec -it 122c297e7298 bash #挂载后进入容器方式,容器id 使用此命令进入mysql需要先执行docker ps 找到mysql镜像id mysql -uroot -p use mysql flush privileges; ALTER USER 'root'@'localhost' IDENTIFIED BY 'root'; flush privileges; exit
未挂载docker镜像时可以使用以这种方式进入MySQL
#如需本地navicat连接需要配置访问规则 docker exec -it mysql /bin/bash mysql -uroot -p use mysql flush privileges; ALTER USER 'root'@'%' IDENTIFIED BY 'root' PASSWORD EXPIRE NEVER; #修改加密规则 ALTER USER 'root'@'%' IDENTIFIED WITH mysql_native_password BY 'root'; #修改密码 flush privileges; #刷新数据
已挂载docker镜像
docker ps #找到mysql镜像id docker exec -it MySQL镜像ID bash mysql -uroot -p use mysql flush privileges; ALTER USER 'root'@'%' IDENTIFIED BY 'root' PASSWORD EXPIRE NEVER; #修改加密规则 ALTER USER 'root'@'%' IDENTIFIED WITH mysql_native_password BY 'root'; #修改密码 flush privileges; #刷新数据Redis
拉取官方redis镜像
docker pull redis
创建容器
docker run -di --name redis -p 6379:6379 redis
连接容器中的Redis时,只需要连接宿主机的IP + 指定的映射端口即可。
Compose 安装下载
# 因为Docker Compose存放在GitHub,可能不太稳定。可以通过DaoCloud加速下载 curl -L https://get.daocloud.io/docker/compose/releases/download/1.26.2/docker-compose-`uname -s`-`uname -m` > /usr/local/bin/docker-compose
授权
# 将可执行权限应用于该二进制文件 sudo chmod +x /usr/local/bin/docker-compose
测试
docker-compose --version
卸载谨慎操作,此处仅提供卸载方法,如有需要可执行此命令
rm /usr/local/bin/docker-compose配置docker目录下的文件 很重要 服务打jar包
在运行代码正常无bug情况下开始打包操作
首先将所有服务停止 maven执行clean操作(请保证执行clean操作是在ruoyi(root)里进行操作) 如果clean操作target包未被删除执行以下操作清除缓存重启idea成功后重复上述操作
修改bootstrap.yml配置文件[这里非常重要]其他服务bootstrap.yml配置与auth保持一致
ruoyi-gateway如不需要使用sentinel可以将此处注释
将所有模块配置完成后进行maven打jar包操作(在模块未运行的情况下进行打包操作)
执行完毕可以看到所在模块下已经生成target文件了
操作docker/ruoyi 将生成的jar包放入若依自带的docker文件夹指定目录其余文件夹jar包操作参考上文
在docker文件夹下ruoyi目录的操作到此为止dockerfile文件无需进行操作 操作docker/mysql 将SQL文件导出至此文件夹目录下 因为我们在docker里面安装的是mysql8.0版本所以下面需要进行修改一下配置 操作docker/nacos进入此目录编辑nacos配置文件
编辑docker/nacos下dockerfile文件
将默认状态修改为指定nacos版本此处如果不做配置nacos启动时会再次拉取nacos镜像最新版本
操作dockernginxconf编辑这个文件
建议使用默认配置
因为我们在docker中拉取的是nginx最新版本索引nginx的dockerfile不需要进行修改操作
操作dockernginxhtmldist这个文件此处将前端代码打包,只介绍在idea打包方式,前端项目打包可让前端进行打包
进入ruoyi-ui目录
执行npm run build:prod命令,[执行此命令前置操作下载前端依赖需执行npm install --registry=https://registry.npm.taobao.org命令]
docker/redis无需进行操作 操作docker下docker-compose.yml文件编辑此文件
因为拉去的nacos镜像为2.0.4版本,mysql镜像为8.0版本索引进行以下操作
将docker文件夹上传至linux 上传docker文件 启动服务 首先禁用防火墙1、命令行界面输入命令“systemctl status firewalld.service”并按下回车键。
systemctl status firewalld.service
2、然后在下方可度以查看得到“active(running)”,此时说明防火墙已经被打开了。
3、在命令行中输入systemctl stop firewalld.service命令,进行关闭防火墙。
systemctl stop firewalld.service
4、然后再使用命令systemctl status firewalld.service,在下方出现disavtive(dead),这权样就说明防火墙已经关闭。
5、再在命令行中输入命令“systemctl disable firewalld.service”命令,即可永久关闭防火墙。
systemctl disable firewalld.service查看docker日志
# 输出日志,不同的服务输出使用不同的颜色来区分 docker-compose logs # 跟踪日志输出 docker-compose logs -f # 关闭颜色 docker-compose logs --no-color运行服务 查看所侦听的端口
netstat -luntp #用于查看服务端口是否被侦听
cd /home/docker/ #进入docker文件所在目录 ./deploy.sh port # 开启所需端口 因为在之前已经关闭防火墙,此命令无需执行 #注意执行完此命令后请执行 docker-compose logs -f #跟踪启动服务的日志打印 #如有报错说明配置有误,请先解决完报错保证nacos,mysql,redis启动成功 ./deploy.sh base # 启动基础环境(必须)nacos启动成功 连接nacos
IP地址为虚拟机IP地址
http://192.168.136.135:8848/nacos
访问成功
编辑nacos配置
此处仅介绍system配置,其他配置参考system配置即可
测试mysql连接 测试redis连接配置完成后执行下面命令保证修改后的配置能够被服务读取
./deploy.sh stop # 关闭所有环境/模块 重启服务时执行此操作保证修改的配置被读取 ./deploy.sh rm # 删除所有环境/模块 重启服务时执行此操作保证修改的配置被读取启动服务
执行完以上命令后再次执行以下命令
./deploy.sh base #执行完此命令请等待两分钟保证nacos,mysql,redis成功启动后执行后续命令 ./deploy.sh modules # 启动程序模块(必须)base命令成功启动完服务后执行此命令
执行完./deploy.sh base命令后在linux中查看正在运行的容器,以下为成功启动并运行
执行./deploy.sh modules命令后请及时 跟进日志打印查看服务是否启动成功
服务启动成功
浏览器访问http://192.168.136.135 IP地址为虚拟机IP地址,默认访问80端口
报错问题解决 运行.sh报错-bash: ./xxx.sh: Permission denied处理如果你是root登陆的话(不是的话,切换到root用户,对*.sh赋可执行的权限)
chmod +x *.sh #执行此命令执行./deploy.sh base 后查看日志[docker-compose logs]nacos出现mbind: Operation not permitted
参考链接:https://blog.csdn.net/liuyunshengsir/article/details/123197825
在[mysqld]的段中加上一句:skip-name-resolve
vim /etc/my.cnf [mysqld] datadir=/var/lib/mysql socket=/var/lib/mysql/mysql.sock skip-name-resolve
重启mysql即可
//重启mysql步骤 docker ps //查看当前正在运行的容器 //找到mysql的镜像id docker restart 镜像id执行./deploy.sh basemysql显示[Warning] IP address ‘xxxx’ could not be resolved: Name or service not known错误解决
参考链接:https://blog.csdn.net/u013591306/article/details/77602553
进入/etc 找到mysql的配置文件my.cnf(linux环境下)或者my.ini(windows环境下)进行编辑加入如下一行即可: [mysqld] skip-name-resolve执行./deploy.sh modules出现此报错
请参考https://blog.51cto.com/u_14832233/3988418
通过重启 docker 服务解决这个问题 注意重启docker之后base服务会被停止需重新执行7.1启动服务
service docker restart #重启 docker 服务使用mysql8.0执行./deploy.sh base命令如果遇到Caused by: com.mysql.cj.exceptions.CJException: Public Key Retrieval is not错误
参考链接:https://liuhuanhuan.blog.csdn.net/article/details/116583828?spm=1001.2101.3001.6650.1&utm_medium=distribute.pc_relevant.none-task-blog-2%7Edefault%7ECTRLIST%7ERate-1.pc_relevant_antiscanv2&depth_1-utm_source=distribute.pc_relevant.none-task-blog-2%7Edefault%7ECTRLIST%7ERate-1.pc_relevant_antiscanv2&utm_relevant_index=2
编辑nacos配置文件
8418
通过重启 docker 服务解决这个问题 注意重启docker之后base服务会被停止需重新执行7.1启动服务
service docker restart #重启 docker 服务使用mysql8.0执行./deploy.sh base命令如果遇到Caused by: com.mysql.cj.exceptions.CJException: Public Key Retrieval is not错误
参考链接:https://liuhuanhuan.blog.csdn.net/article/details/116583828?spm=1001.2101.3001.6650.1&utm_medium=distribute.pc_relevant.none-task-blog-2%7Edefault%7ECTRLIST%7ERate-1.pc_relevant_antiscanv2&depth_1-utm_source=distribute.pc_relevant.none-task-blog-2%7Edefault%7ECTRLIST%7ERate-1.pc_relevant_antiscanv2&utm_relevant_index=2
编辑nacos配置文件



