Docker容器化部署若依微服务ruoyi-cloud项目

系统环境

图片.png

接下来的内容以 Ubuntu 22.04.1 操作系统为例。

下载安装Docker

Ubuntu

hi@hi-IdeaCentre-GeekPro-15ICK:~$ sudo su
[sudo] hi 的密码: 
root@hi-IdeaCentre-GeekPro-15ICK:/home/hi# docker ps
找不到命令 “docker”,但可以通过以下软件包安装它:
apt install docker.io      # version 24.0.5-0ubuntu1~22.04.1, or
apt install podman-docker  # version 3.4.4+ds1-1ubuntu1.22.04.2

root@hi-IdeaCentre-GeekPro-15ICK:/home/hi# docker-compose 
找不到命令 “docker-compose”,但可以通过以下软件包安装它:
apt install docker-compose

验证版本信息

root@hi-IdeaCentre-GeekPro-15ICK:/home/hi# docker -v
Docker version 24.0.5, build 24.0.5-0ubuntu1~22.04.1

root@hi-IdeaCentre-GeekPro-15ICK:/home/hi# docker-compose -version
docker-compose version 1.29.2, build unknown

CentOS7

yum install -y yum-utils # yum工具集
yum-config-manager --add-repo https://mirrors.aliyun.com/docker-ce/linux/centos/docker-ce.repo
yum makecache fast # yum自动检测最快的安装源
yum install -y docker-ce
systemctl start docker 
docker version
[root@docker ~]# docker -v
Docker version 24.0.6, build ed223bc
docker pull hello-world
docker run hello-world

Note: 在 CentOS7 上使用上述 yum 方式安装的 Docker ,默认自带了Docker Compose Plugin,不过命令是 docker compose

[root@docker ~]# docker compose version
Docker Compose version v2.21.0

Docker基本操作

基础操作

  • docker pull
  • docker run
  • docker images
  • docker ps
  • docker logs
  • docker start
  • docker stop
  • docker restart
  • docker rmi
  • docker rm
  • docker exec
  • docker network
  • docker inspect
  • docker build

命令的具体用法可参考:云原生之容器编排实践-在CentOS7上安装使用Docker

批量操作

常用的批量操作命令:

# 停止所有运行中的容器
docker stop $(docker ps -q)

# 删除所有容器
docker rm $(docker ps -aq)

# 删除所有镜像
docker rmi $(docker images -aq)

# 强制删除所有未被容器使用的镜像
docker image prune -a -f

# 查看所有的无用卷
docker volume ls -qf dangling=true

# 删除无用卷
docker volume rm $(docker volume ls -qf dangling=true)

# 强制清理退出的容器快照
docker rm $(docker ps -q -f status=exited)

# 清理dangling image
docker rmi $(docker images --filter "dangling=true" -q --no-trunc)

下载若依微服务项目源码

如果是下载压缩包的方式,那么先初始化为 git 项目,初始提交,再切换分支,方便做版本管理。

Heartsuit@LAPTOP MINGW64 /d/Java/IdeaProjects/RuoYi-Cloud-master
$ git init
Initialized empty Git repository in D:/Java/IdeaProjects/RuoYi-Cloud-master/.git/

Heartsuit@LAPTOP MINGW64 /d/Java/IdeaProjects/RuoYi-Cloud-master (master)
$ git add .

Heartsuit@LAPTOP MINGW64 /d/Java/IdeaProjects/RuoYi-Cloud-master (master)
$ git commit -m "initial commit"

Heartsuit@LAPTOP MINGW64 /d/Java/IdeaProjects/RuoYi-Cloud-master (master)
$ git checkout -b deploy
Switched to a new branch 'deploy'

Heartsuit@LAPTOP MINGW64 /d/Java/IdeaProjects/RuoYi-Cloud-master (deploy)
$ git merge master
Already up to date.

修改配置

由于生产环境与开发环境的配置不同,实际操作时,一般先切换一个分支,专门用于生产环境的配置调整。

MySQL版本

根据需要修改 MySQL 版本,我们用的是 8.0 ,对应的文件: docker/mysql/dockerfile

图片.png

修改docker-compose.yml:数据库版本、名称与密码;

对应的文件: docker/docker-compose.yml

图片.png

Note:经测试,如果遇到在不同操作系统的宿主机上或者不同版本的 Dockerdocker-compose 下, docker-entrypoint-initdb.d 目录下的 SQL 语句并没有成功执行;原因是没有执行 MySQLDockerfilebuild 操作,导致并没有将 SQL 文件 COPYdocker-entrypoint-initdb.d 目录下。解决方法有两种:

  1. 删除docker-compose.ymlMySQLimage
  2. 增加SQL文件目录的挂载至/docker-entrypoint-initdb.d目录。

图片.png

Nacos连接数据库地址

对应的文件: docker/nacos/conf/application.properties

1700276442016.jpg

Note:

  • 如果修改了docker-compose中数据库服务的服务名,那么上图中的数据库服务:ruoyi-mysql也要一并修改。
  • 另外,如果在生产环境下,发现Nacos持续报没有数据源:No Datasource Set,这时候可以尝试修改下connectTimeout的值,从1000改为10000,连接超时数据1s改为10s,这是以为网络延迟导致的Nacos无法在指定的时间内连接上MySQL

Nginx配置

对应的文件: docker/nginx/conf/nginx.conf ,根据实际服务名与端口号进行配置,我这里保持默认

图片.png

Redis配置

对应的文件: docker/redis/conf/redis.conf我这里保持默认

导出数据库脚本放到mysql/db目录

可以使用若依自带的 SQL 脚本,或者导出自己的数据库表(包含建库、建表以及Insert语句),手动放到 docker/mysql/db 下。
Note:

  • docker-entrypoint-initdb.d这个目录下的SQL或者sh文件会在数据库初始化时执行;
  • 我这里修改了数据库的名称,分别为my-cloudmy-config

修改业务服务配置文件中连接Nacos的地址

根据实际要部署到生产环境的服务,修改对应的 bootstrap.yml 文件;这里以网关服务、认证服务以及系统服务为例,将其中的127.0.0.1改为 docker-composeNacos 的服务名: ruoyi-nacos

1700290596260.jpg

扩展docker-compose配置:新增MinIO服务

docker 目录下新建一个 minio 目录,在其中新增一个 dockerfile 文件与 confdata 目录(这几个文件暂时没用,后期可用于自定义配置);然后在 docker-compose.yml 中添加 ruoyi-minio 服务。

图片.png

Note:在同一个 docker-compose.yml 中的服务启动后,默认是在同一个网络下,可以通过服务名称进行通信,因此如果这里的 minio 是单独部署,而不是配置在 docker-compose.yml 中,那么无法通过服务名称 ruoyi-minio 连接。

修改Nacos配置中心的数据库、缓存

作为配置中心, Nacos 中存放了各个服务的核心配置,eg:数据库连接、缓存、对象存储等,所以等一会儿 MySQLNacos 启动后,在业务服务启动之前,需要先将Nacos中的以下内容改为服务名称;这里以网关服务、认证服务以及系统服务为例。

  • Redis的localhost改为ruoyi-redis;
  • MySQL的localhost改为ruoyi-mysql;
  • 数据库名称与用户名、密码根据实际修改即可。

图片.png

编译打包部署

前端

在项目根目录( package.json 所在目录)执行打包命令:

npm run build:prod

会生成 dist 的静态资源目录;我这里因为前后端分离开发,打包后直接将dist目录放到 docker/nginx/html/ 下。

后端

在项目根目录(最外层pom.xml所在目录)执行打包命令,这里为加快打包进度,跳过了单元测试:

mvn clean package -Dmaven.test.skip=true

会在各模块或者微服务的 target 目录下生成 模块名.jar 的可执行文件。

Copy

由于微服务较多,若依提供了复制脚本,将不同的微服务打包后的 jar 复制到待部署的 docker 目录下;根据需要修改 copy.sh 的内容,建议使用 bash

#!/bin/sh

# 复制项目的文件到对应docker路径,便于一键生成镜像。
usage() {
	echo "Usage: sh copy.sh"
	exit 1
}

# copy jar
echo "begin copy ruoyi-gateway "
cp ../ruoyi-gateway/target/ruoyi-gateway.jar ./ruoyi/gateway/jar

echo "begin copy ruoyi-auth "
cp ../ruoyi-auth/target/ruoyi-auth.jar ./ruoyi/auth/jar

echo "begin copy ruoyi-modules-system "
cp ../ruoyi-modules/ruoyi-system/target/ruoyi-modules-system.jar ./ruoyi/modules/system/jar

图片.png

部署

准备好前端后端以及所有的配置文件后,可以将若依项目下的 docker 目录直接上传到服务器。

  1. 为了避免因权限问题导致部署失败,建议先赋权限(777,简单粗暴;实际生产环境可根据需要配置权限。)
chown -R root:root docker
chmod -R 777 docker
  1. 切换至docker-compose.yml所在目录
  • docker-compose -f docker-compose.yml up -d ruoyi-mysql ruoyi-redis ruoyi-nacos ruoyi-minio
  • docker-compose -f docker-compose.yml up -d ruoyi-gateway ruoyi-nginx ruoyi-auth ruoyi-modules-system
  1. 重新部署指定容器
  • docker stop ruoyi-gateway ruoyi-nginx ruoyi-auth ruoyi-modules-system
  • docker rm ruoyi-gateway ruoyi-nginx ruoyi-auth ruoyi-modules-system
  • docker rmi docker_ruoyi-gateway docker_ruoyi-auth docker_ruoyi-modules-system

验证服务

所有相关容器已正常运行。

图片.png

所有微服务已注册成功。

图片.png

前端可以正常打开登录。

图片.png

离线部署容器化的微服务

离线安装Docker

参考:CentOS7.8离线安装Docker24.0.2,离线安装gcc与g++环境

离线部署微服务

实际场景中,有时候服务器环境不允许连接外网,导致无法从镜像仓库拉取镜像;针对这种情况, Docker 提供了 saveload 命令来实现镜像的导出与导入。

  1. 导出镜像

docker save -o <file-name.tar>

  1. 导入镜像

docker load -i <file-path.tar>

  1. 验证导入的镜像

docker images

# 保存镜像
docker save redis:latest -o redis.tar
docker save mysql:8.0 -o mysql.tar
docker save nginx:latest -o nginx.tar
docker save minio/minio:latest -o minio.tar
docker save nacos/nacos-server:latest -o nacos.tar
docker save openjdk:8-jre -o openjdk.tar
docker save docker-ruoyi-gateway:latest -o docker-ruoyi-gateway.tar
docker save docker-ruoyi-auth:latest -o docker-ruoyi-auth.tar
docker save docker-ruoyi-modules-system:latest -o docker-ruoyi-modules-system.tar

# 加载镜像
docker load -i redis.tar
docker load -i minio.tar 
docker load -i mysql.tar 
docker load -i nacos.tar 
docker load -i nginx.tar
docker load -i openjdk.tar
docker load -i docker-ruoyi-gateway.tar
docker load -i docker-ruoyi-auth.tar 
docker load -i docker-ruoyi-modules-system.tar 

离线导入数据库

可以通过 MySQL 数据库的 source 命令将 SQL 语句(建库、建表以及Insert语句)导入目标库。

Note:离线导入镜像的局限性:在 X86_64 平台上制作的 Image 不可在 ARM 平台(M1 视同为 ARM)上使用,反之亦然。

Docker可视化管理工具

Windows上的Docker Desktop

主要用于开发或者测试环境,略。。

IDEA连接Docker服务

参考:云原生之容器编排实践-通过IDEA连接Docker服务

Portainer图形化容器管理

安装Portainer

[root@docker ~]# cd /opt/
[root@docker opt]# mkdir portainer
[root@docker opt]# docker pull portainer/portainer
[root@docker opt]# docker run -p 9000:9000 -p 8000:8000 --name portainer \
--restart=always \
-v /var/run/docker.sock:/var/run/docker.sock \
-v /opt/portainer/data:/data \
-d portainer/portainer

设置密码

1699877376740.jpg

选择环境

1699877432366.jpg

1699877454503.jpg

Dashboard

图片.png

容器管理

图片.png

查看日志

图片.png

容器详情

图片.png

进入容器

图片.png

Reference

http://doc.ruoyi.vip/ruoyi-cloud/cloud/dokcer.html

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mfbz.cn/a/189316.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

C# 使用NPOI操作Excel的工具类

写在前面 NPOI是POI项目的.NET迁移版本。POI是一个开源的Java 读写 Excel、Word 等微软Ole2组件文档的项目&#xff1b;使用NPOI可以在没有安装Office或者相应环境的机器上对Word或Excel文档进行读写操作。 NPOI类库中操作EXCEL有两个模块分别是&#xff1a; 1️.HSSF模块&a…

Java每日一题:26. 删除有序数组中的重复项

删除有序数组中的重复项 分析&#xff1a; 数组是有序的&#xff0c;因此重复的元素会相邻 每次取出两个数进行比较&#xff0c;因此&#xff0c;需要有两个变量去存储每次取出的值 采用双指针方法&#xff1a; 指针p和q&#xff0c; pnum1&#xff0c;qnum2 p和q进行比较&…

一些在使用Python中常用网页字符串处理方法

嗨喽~大家好呀&#xff0c;这里是魔王呐 ❤ ~! python更多源码/资料/解答/教程等 点击此处跳转文末名片免费获取 首先一些Python字符串处理的简易常用的用法。 1.去掉重复空格 s "hello hello hello" s .join(s.split())2.去掉所有回车&#xff08;或其他字…

可验证随机函数(VRF)

文章目录 一、背景以及场景共识发展第一代 POW “以力取胜”第二代 POS/DPOS “民主投票”第三代 VRF “运气抽签” 二、可验证随机函数&#xff08;VRF&#xff09;快速开始1. VRF是什么?2. MD5 hash函数和VRF&#xff08;Verifiable Random Function&#xff09;区别3. VRF-…

Java核心知识点整理大全15-笔记

Java核心知识点整理大全-笔记_希斯奎的博客-CSDN博客 Java核心知识点整理大全2-笔记_希斯奎的博客-CSDN博客 Java核心知识点整理大全3-笔记_希斯奎的博客-CSDN博客 Java核心知识点整理大全4-笔记-CSDN博客 Java核心知识点整理大全5-笔记-CSDN博客 Java核心知识点整理大全6…

h5小游戏--2048

2048 经典2048小游戏&#xff0c;基于JS、Html5改写版 效果预览 点我下载源代码 下载代码解压后&#xff0c;双击index.html即可开始本游戏。 Game Rule 游戏规则 以下为游戏默认规则&#xff0c;若需要修改规则请修改代码。 移动箭头键来移动方块&#xff0c;当两个相同数…

visual studio 下的git

我这个是看视频笔记 YouTube : https://www.youtube.com/watch?vgkDASVE_Hdg 主要内容是&#xff1a;建立git 库&#xff0c; 保存commit&#xff0c; 建立分支 create branch, 合并分支merge branch,比较 diff&#xff0c;Revert ,history,delete branch, rename branch, t…

OpenCV快速入门:相机标定——单目视觉和双目视觉

文章目录 前言一、相机标定的基本原理1.1 相机模型与坐标系1.1.1 相机模型1.1.2 坐标系 1.2 相机内参与外参1.2.1 内部参数1.2.2 外部参数 1.3 镜头畸变1.4 透视变换1.5 标定的重要性和应用场景 二、单目视觉2.1 单目视觉的原理2.1.1 单目视觉的原理2.1.2 单目视觉的公式2.1.3 …

【JMeter】不同场景下的接口请求

场景1: 上传文件接口即Content-Type=multipart/form-data 步骤: 1. 接口url,method以及path正常填写 2.文件上传content-type是multipart/form-data,所以可以勾选【use multipart/form-data】,如果还有其他请求头信息可以添加一个请求头元件 3.请求参…

(2023码蹄杯)省赛(初赛)第三场真题(原题)(题解+AC代码)

题目1&#xff1a;MC0227堆煤球 码题集OJ-堆煤球 (matiji.net) 思路&#xff1a; 1.i从l枚举到r,i是8的倍数就跳过&#xff0c;i不是8的倍数就用等差数列求和公式i(1i)/2,最后累加到答案中即可 AC_Code:C #include<bits/stdc.h> using namespace std;int main( ) {in…

pytorch分布式训练

1 基本概念 rank&#xff1a;进程号&#xff0c;在多进程上下文中&#xff0c;我们通常假定rank 0是第一个进程或者主进程&#xff0c;其它进程分别具有1&#xff0c;2&#xff0c;3不同rank号&#xff0c;这样总共具有4个进程 node&#xff1a;物理节点&#xff0c;可以是一个…

分布式篇---第七篇

系列文章目录 文章目录 系列文章目录前言一、如何将长链接转换成短链接,并发送短信?二、长链接和短链接如何互相转换?三、长链接和短链接的对应关系如何存储?四、如何提高系统的并发能力?前言 前些天发现了一个巨牛的人工智能学习网站,通俗易懂,风趣幽默,忍不住分享一…

Docker Swarm总结+CI/CD Devops、gitlab、sonarqube以及harbor的安装集成配置(3/4)

博主介绍&#xff1a;Java领域优质创作者,博客之星城市赛道TOP20、专注于前端流行技术框架、Java后端技术领域、项目实战运维以及GIS地理信息领域。 &#x1f345;文末获取源码下载地址&#x1f345; &#x1f447;&#x1f3fb; 精彩专栏推荐订阅&#x1f447;&#x1f3fb;…

Guitar Pro8.0.2吉他编曲软件 吉他打谱软件 吉他作曲软件

Guitar Pro8.0.2在音乐的大舞台上&#xff0c;谁不想成为一位吉他弹奏大师呢&#xff1f;但在现实中&#xff0c;学吉他并非一蹴而就&#xff0c;许多小伙伴都因为吉他的上手难度而被浇灭学习的热情。然而&#xff0c;这里有一款神奇的软件&#xff0c;叫做&#xff0c;它就像是…

bugku 渗透测试

场景1 查看源代码 场景2 用dirsearch扫描一下看看 ok看到登录的照应了第一个提示 进去看看 不出所料 随便试试admin/admin进去了 在基本设置里面看到falg 场景3 确实是没啥想法了 找到php在线运行 检查网络&#xff0c;我们发现这个php在线运行会写入文件 那我们是不是写…

【数据结构】树与二叉树(廿五):树搜索指定数据域的结点(算法FindTarget)

文章目录 5.3.1 树的存储结构5. 左儿子右兄弟链接结构 5.3.2 获取结点的算法1. 获取大儿子、大兄弟结点2. 搜索给定结点的父亲3. 搜索指定数据域的结点a. 算法FindTargetb. 算法解析c. 代码实现a. 使用指向指针的指针b. 直接返回找到的节点 4. 代码整合 5.3.1 树的存储结构 5.…

Visual Studio 使用MFC 单文档工程绘制单一颜色直线和绘制渐变颜色的直线(实例分析)

Visual Studio 使用MFC 单文档工程从创建到实现绘制单一颜色直线和绘制渐变颜色的直线 本文主要从零开始创建一个MFC单文档工程然后逐步实现添加按键&#xff08;事件响应函数&#xff09;&#xff0c;最后实现单一颜色直线的绘制与渐变色直线的绘制o(&#xffe3;▽&#xffe…

利用chart.js来完成动态网页显示拆线图的效果

<% page language"java" contentType"text/html; charsetUTF-8"pageEncoding"UTF-8"%><%! String list"[一月份, 二月份, 三月份,四月份, 五月份, 六月份, 七月]"; String label"我的一个折线图"; String data &qu…

RabbitMQ之MQ的可靠性

文章目录 前言一、数据持久化交换机持久化队列持久化消息持久化 二、LazyQueue控制台配置Lazy模式代码配置Lazy模式更新已有队列为lazy模式 总结 前言 消息到达MQ以后&#xff0c;如果MQ不能及时保存&#xff0c;也会导致消息丢失&#xff0c;所以MQ的可靠性也非常重要。 一、…

Scrapy爬虫异步框架(一篇文章齐全)

1、Scrapy框架初识 2、Scrapy框架持久化存储&#xff08;点击前往查阅&#xff09; 3、Scrapy框架内置管道&#xff08;点击前往查阅&#xff09; 4、Scrapy框架中间件&#xff08;点击前往查阅&#xff09; Scrapy 是一个开源的、基于Python的爬虫框架&#xff0c;它提供了…
最新文章