• ruoyi-cloud微服务在Linux中使用docker-compose部署


    ruoyi-cloud微服务docker-compose部署

    前置说明

    **在本地安装虚拟机请务必给虚拟机分配足够内存!!!,**否则服务可能会在启动中挂掉

    分配4G内存我这边是够的,具体需要分配多少内存请根据实际情况加上微服务数量来分配内存
    在这里插入图片描述

    搭建服务中常用的命令

    docker中常用的命令

    docker images		#查看镜像
    docker ps			#查看正在运行的容器
    docker ps -a		#查看所有容器(包括运行和停止)
    
    • 1
    • 2
    • 3

    docker-compose命令

    #以下命令需安装完docker-compose后方可执行查看效果
    docker-compose logs		#查看启动服务所打印的日志
    docker-compose logs -f 	#跟踪启动服务的日志打印
    docker-compose up -d	# 后台启动
    
    • 1
    • 2
    • 3
    • 4

    端口侦听

    netstat -luntp			#查看所有服务启动后端口是否被侦听*这个很重要*
    
    • 1

    Docker 环境安装

    安装所需的软件包

    yum install -y yum-utils
    
    • 1

    设置存储库

    # 阿里云地址(国内地址,相对更快)
    yum-config-manager 
    --add-repo 
    http://mirrors.aliyun.com/docker-ce/linux/centos/docker-ce.repo
    
    • 1
    • 2
    • 3
    • 4

    安装Docker引擎

    yum install docker-ce docker-ce-cli containerd.io
    
    • 1

    安装完成后,运行下面的命令,验证是否安装成功。

    docker version # 查看Docker版本信息
    
    systemctl start docker		# 启动 docker 服务:
    systemctl stop docker		# 停止 docker 服务:
    systemctl status docker		# 查看 docker 服务状态
    systemctl restart docker	# 重启 docker 服务
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6

    配置镜像

    使用配置文件/etc/docker/daemon.json(没有时新建该文件)

    vim /etc/docker/daemon.json
    # 添加如下内容,可以自己替换。默认地址是我的创建的
    {
      "registry-mirrors": ["https://mr63yffu.mirror.aliyuncs.com"]
    }
    
    • 1
    • 2
    • 3
    • 4
    • 5

    重启Docker Daemon即可

    systemctl daemon-reload
    
    • 1

    应用部署

    Nacos

    拉取官方nacos镜像
    在这里插入图片描述

    目前若依微服务最新版本需要安装的是2.0.4版本,如需更改请根据实际情况修改拉取的版本号

    docker pull nacos/nacos-server:v2.0.4
    
    • 1

    启动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
    
    • 1

    MODE=standalone表示单机启动

    Nginx

    拉取官方nginx镜像,默认拉取最新版本

    docker pull nginx
    
    • 1

    创建Nginx容器。

    docker run -di --name nginx -p 80:80 nginx
    
    • 1

    将容器内的配置文件拷贝到指定目录(请先提前创建好目录)。

    # 创建目录
    mkdir -p /home/ruoyi/nginx
    
    # 将容器内的配置文件拷贝到指定目录
    docker cp nginx:/etc/nginx /home/ruoyi/nginx/conf
    
    • 1
    • 2
    • 3
    • 4
    • 5

    终止并删除容器 需要执行

    docker stop nginx
    docker rm nginx
    
    • 1
    • 2

    创建Nginx容器,并将容器中的/etc/nginx目录和宿主机的/home/ruoyi/nginx/conf目录进行挂载。

    docker run -di --name nginx -p 80:80 -v /home/ruoyi/nginx/conf:/etc/nginx nginx
    
    • 1

    Mysql

    拉取官方mysql8.0镜像

    docker pull mysql:8.0
    
    • 1

    在本地创建mysql的映射目录

    mkdir -p /home/mysql/data /home/mysql/logs /home/mysql/conf
    
    • 1

    创建容器,将数据、日志、配置文件映射到本机

    #此处的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
    
    • 1
    • 2

    进入容器/执行命令: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
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8

    未挂载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; #刷新数据
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8

    已挂载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; #刷新数据
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8

    Redis

    拉取官方redis镜像

    docker pull redis
    
    • 1

    创建容器

    docker run -di --name redis -p 6379:6379 redis
    
    • 1

    连接容器中的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
    
    • 1
    • 2

    授权

    # 将可执行权限应用于该二进制文件
    sudo chmod +x /usr/local/bin/docker-compose
    
    • 1
    • 2

    测试

    docker-compose --version
    
    • 1

    卸载谨慎操作,此处仅提供卸载方法,如有需要可执行此命令

    rm /usr/local/bin/docker-compose
    
    • 1

    配置docker目录下的文件 很重要

    服务打jar

    在运行代码正常无bug情况下开始打包操作

    首先将所有服务停止

    在这里插入图片描述

    maven执行clean操作(请保证执行clean操作是在ruoyi(root)里进行操作)

    在这里插入图片描述

    在这里插入图片描述

    如果clean操作target包未被删除执行以下操作

    在这里插入图片描述

    在这里插入图片描述

    清除缓存重启idea成功后重复上述操作

    修改bootstrap.yml配置文件[这里非常重要]

    在这里插入图片描述

    其他服务bootstrap.yml配置与auth保持一致

    ruoyi-gateway如不需要使用sentinel可以将此处注释

    在这里插入图片描述

    将所有模块配置完成后进行mavenjar包操作(在模块未运行的情况下进行打包操作)

    在这里插入图片描述

    执行完毕可以看到所在模块下已经生成target文件了

    在这里插入图片描述

    操作docker/ruoyi

    将生成的jar包放入若依自带的docker文件夹指定目录

    在这里插入图片描述

    在这里插入图片描述

    在这里插入图片描述

    其余文件夹jar包操作参考上文

    在docker文件夹下ruoyi目录的操作到此为止dockerfile文件无需进行操作

    在这里插入图片描述

    操作docker/mysql

    将SQL文件导出至此文件夹目录下

    在这里插入图片描述

    因为我们在docker里面安装的是mysql8.0版本所以下面需要进行修改一下配置

    在这里插入图片描述

    在这里插入图片描述

    操作docker/nacos

    进入此目录编辑nacos配置文件

    在这里插入图片描述

    在这里插入图片描述

    编辑docker/nacosdockerfile文件

    在这里插入图片描述

    将默认状态修改为指定nacos版本此处如果不做配置nacos启动时会再次拉取nacos镜像最新版本

    在这里插入图片描述

    操作docker ginxconf

    编辑这个文件

    在这里插入图片描述

    建议使用默认配置

    在这里插入图片描述

    因为我们在docker中拉取的是nginx最新版本索引nginx的dockerfile不需要进行修改操作

    操作docker ginxhtmldist这个文件

    此处将前端代码打包,只介绍在idea打包方式,前端项目打包可让前端进行打包

    进入ruoyi-ui目录

    在这里插入图片描述

    执行npm run build:prod命令,[执行此命令前置操作下载前端依赖需执行npm install --registry=https://registry.npm.taobao.org命令]

    在这里插入图片描述

    在这里插入图片描述

    docker/redis无需进行操作

    操作dockerdocker-compose.yml文件

    编辑此文件

    因为拉去的nacos镜像为2.0.4版本,mysql镜像为8.0版本索引进行以下操作

    在这里插入图片描述

    在这里插入图片描述

    将docker文件夹上传至linux

    上传docker文件

    在这里插入图片描述

    启动服务

    首先禁用防火墙

    1、命令行界面输入命令“systemctl status firewalld.service”并按下回车键。

    systemctl status firewalld.service
    
    • 1

    2、然后在下方可度以查看得到“active(running)”,此时说明防火墙已经被打开了。

    3、在命令行中输入systemctl stop firewalld.service命令,进行关闭防火墙。

    systemctl stop firewalld.service
    
    • 1

    4、然后再使用命令systemctl status firewalld.service,在下方出现disavtive(dead),这权样就说明防火墙已经关闭。

    5、再在命令行中输入命令“systemctl disable firewalld.service”命令,即可永久关闭防火墙。

    systemctl disable firewalld.service
    
    • 1

    查看docker日志

    # 输出日志,不同的服务输出使用不同的颜色来区分
    docker-compose logs
    # 跟踪日志输出
    docker-compose logs -f
    # 关闭颜色
    docker-compose logs --no-color
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6

    运行服务

    查看所侦听的端口

    netstat -luntp			#用于查看服务端口是否被侦听
    
    
    cd /home/docker/		#进入docker文件所在目录
    
    ./deploy.sh port		# 开启所需端口	因为在之前已经关闭防火墙,此命令无需执行
    	
    #注意执行完此命令后请执行	docker-compose logs -f 	#跟踪启动服务的日志打印 
    #如有报错说明配置有误,请先解决完报错保证nacos,mysql,redis启动成功
    ./deploy.sh base		# 启动基础环境(必须)
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10

    nacos启动成功

    在这里插入图片描述

    连接nacos

    IP地址为虚拟机IP地址

    http://192.168.136.135:8848/nacos
    
    • 1

    访问成功

    在这里插入图片描述

    编辑nacos配置
    在这里插入图片描述

    在这里插入图片描述

    在这里插入图片描述

    此处仅介绍system配置,其他配置参考system配置即可

    测试mysql连接

    在这里插入图片描述

    测试redis连接

    在这里插入图片描述

    配置完成后执行下面命令保证修改后的配置能够被服务读取

    ./deploy.sh stop		# 关闭所有环境/模块		重启服务时执行此操作保证修改的配置被读取
    
    ./deploy.sh rm			# 删除所有环境/模块		重启服务时执行此操作保证修改的配置被读取
    
    • 1
    • 2
    • 3

    启动服务

    执行完以上命令后再次执行以下命令

    ./deploy.sh base		#执行完此命令请等待两分钟保证nacos,mysql,redis成功启动后执行后续命令
    
    ./deploy.sh modules		# 启动程序模块(必须)base命令成功启动完服务后执行此命令
    
    • 1
    • 2
    • 3

    执行完./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			#执行此命令
    
    • 1

    执行./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
    
    • 1
    • 2
    • 3
    • 4
    • 5

    重启mysql即可

    //重启mysql步骤
    docker ps		//查看当前正在运行的容器
    //找到mysql的镜像id
    docker restart 镜像id
    
    • 1
    • 2
    • 3
    • 4

    执行./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
    
    • 1
    • 2
    • 3
    • 4

    执行./deploy.sh modules出现此报错 在这里插入图片描述

    请参考https://blog.51cto.com/u_14832233/3988418

    通过重启 docker 服务解决这个问题 注意重启docker之后base服务会被停止需重新执行7.1启动服务

    service docker restart			#重启 docker 服务
    
    • 1

    使用mysql8.0执行./deploy.sh base命令如果遇到Caused by: com.mysql.cj.exceptions.CJException: Public Key Retrieval is not错误

    参考链接:https://liuhuanhuan.blog.csdn.net/article/details/116583828spm=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 服务
    
    • 1

    使用mysql8.0执行./deploy.sh base命令如果遇到Caused by: com.mysql.cj.exceptions.CJException: Public Key Retrieval is not错误

    参考链接:https://liuhuanhuan.blog.csdn.net/article/details/116583828spm=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配置文件

    在这里插入图片描述

    先自我介绍一下,小编13年上师交大毕业,曾经在小公司待过,去过华为OPPO等大厂,18年进入阿里,直到现在。深知大多数初中级java工程师,想要升技能,往往是需要自己摸索成长或是报班学习,但对于培训机构动则近万元的学费,着实压力不小。自己不成体系的自学效率很低又漫长,而且容易碰到天花板技术停止不前。因此我收集了一份《java开发全套学习资料》送给大家,初衷也很简单,就是希望帮助到想自学又不知道该从何学起的朋友,同时减轻大家的负担。添加下方名片,即可获取全套学习资料哦

  • 相关阅读:
    Unity RawImage
    基于Python的UG二次开发入门
    数据结构-插入排序实现
    Jenkins 设置定时任务
    10款最佳跨浏览器测试工具
    《500强高管谈VE》-VE活动带来的企业体制革新
    读《高性能MySQL》笔记---MySQL架构
    三维GIS的业务导向
    C++之模拟实现map和set
    基于Bootstrap+Django+Python的点菜信息管理系统
  • 原文地址:https://blog.csdn.net/m0_54883970/article/details/126114025