项目地址:
后端
博客前台
博客后台
1.项目部署规划
- 后端多模块项目blog以及各模块运行端口:
前台服务模块sangeng-blog->7777,后台服务模块sangeng-admin->8989,公共模块sangeng-framework
前端前台Vue项目:sg-blog-vue->8093
前端后台Vue项目:sg-vue-admin->8094
docker所需镜像:
java:8(jdk1.8)
mysql:8.0.19
redis:6.0.8
nginx:1.18.0
部署步骤:
- 安装docker
- 拉取java:8镜像,后端项目使用maven打包,上传jar包到服务器指定目录/mydata,编写Dockerfile文件,将后端项目打成镜像文件。
- 拉取mysql:8.0.19、redis:6.0.8、nginx:1.18.0镜像。
- 编写docker-compose.yml文件,使用docker-compose容器编排管理容器运行。
- 配置mysql,导入sql文件
- 配置redis,修改redis.conf文件
- 配置nginx,将打好包的Vue项目放到html目录下,并配置nginx.conf文件
- 测试运行
- 镜像上传阿里云镜像仓库
使用工具:
- IDEA
- Navicat
- ApiFox
- Mobaxterm
2.前置工作
2.1修改后端配置文件ip
修改后端项目的application.yaml文件,将MySQL服务和Redis服务的localhost修改为服务器ip
2.2修改前端Vue项目运行端口
前台Vue项目修改项目运行端口是在config
文件夹下的index.js
文件当中,运行端口由原来的80变为8093
后台Vue项目修改项目运行端口是在vue.config.js
文件当中,运行端口由原来的8081变为8094
2.3修改前端对应的服务器ip
使用快捷键ctrl+shift+R
全局搜索,将原来的localhost
更改为对应的服务器ip
前台Vue项目
- 后台Vue项目
将原来的开发环境和生产环境的VUE_APP_BASE_API
都更改为你的服务器ip和后端子模块端口
2.4后端项目打包
- 后端项目使用maven打包
打包后在target目录下生成对应模块的jar包
打包出现的问题:我在打包完成后查看jar包,发现只有16kb,然后试在本地运行jar包测试,果然有错误,报错信息是:xxxxx-0.0.1-SNAPSHOT.jar中没有主清单属性
,原因是不能找到程序的主类,需要修改父pom文件和子模块sangeng-blog
的pom文件和子模块sangeng-admin
的pom文件,修改如下:
2.4.1解决打包问题
- 父pom
- 子模块
sangeng-blog
和子模块sangeng-admin
的pom文件
2.4.2项目打包,本地运行jar包测试
在这之前首先修改配置文件中的mysql和redis服务ip地址
在父pom下首先clean清除先前的jar包,再install打包.(单模块项目首先clean清除先前的jar包,再package打包)
sangeng-blog模块
sangeng-admin模块
进入target目录下,在文件搜索框输入cmd进入Dos窗口,使用命令运行jar包
若未报错则jar包没有问题
2.5前端项目打包
- 前端sangeng-blog模块项目使用下面命令打包
- 前端sangeng-admin模块项目使用下面命令打包
注意:因为后端使用的是Finclip提供的模板,所以生产环境使用的是npm run build:prod
,如果你没有使用提供的模板,就直接使用npm run build
命令。
- 如果你打包的过程中出现以下错误,表示 node.js版本过高,可以关闭node.js安全校验后再打包
- 如果使用出现ERROR,请注释掉以下内容
下面这一步可以先忽略,因为我是后端部署完成之后再在本地测试前端项目的
- 在本地测试,放在Nginx里面测试发现后台只有登录和左边menu能够显现,原因是因为Route目录下的index.js有问题,只有
/login
和/dashborad
由于添加的Route有些多,所以可以直接在Gitee中克隆我的后台项目:
https://gitee.com/xu-huaiang/sg-vue-admin
或者GitHub克隆
https://github.com/sunwebgo/sg-vue-admin
2.6开放端口
- 打开所有需要运行服务的端口
- 重启防火墙
- 可以使用以下命令查看端口是否开放成功
2.7配置安全组规则
在云服务器的安全组中添加规则
我这里是华为云ECS,添加的是入方向规则
3.Docker安装
Docker运行环境要求系统为64位、Linux系统内核版本为 3.8以上
查看自己虚拟机的内核:
开始安装:
一:搭建gcc环境(gcc是编程语言译器)
二:安装需要的软件包
三:安装镜像仓库
官网上的是
但是因为docker的服务器是在国外,所以有时候从仓库中下载镜像的时候会连接被拒绝或者连接超时的情况,所以可以使用阿里云镜像仓库
四:更新yum软件包索引
五:安装docker引擎
六:启动docker
查看docker服务
查看docker版本信息
七:阿里云镜像加速配置
为了提高镜像的拉取、发布的速度,可以配置阿里云镜像加速
查看加速器地址
在CentOS下配置镜像加速器
4.拉取镜像
- 拉取镜像java:8(jdk1.8)
- 拉取镜像mysql:8.0.19
- 拉取镜像redis:6.0.8
- 拉取镜像nginx:1.18.0
查看当前所有镜像:
5.编写Dockerfile文件,构建镜像
- 首先将jar包传到服务器指定目录下
我这里是在根目录下创建了一个mydata目录
- 在mydata目录下创建Dockerfile文件,编写Dockersfile文件
这里我们两个jar包分别打成两个镜像,因为一个目录下只能有一个Dockerfile文件,所以当构建完第一个镜像之后修改对应的Dockerfile文件。
在vim模式下 :set paste
粘贴的文本数据不会乱
第一个Dockerfile文件
- 构建镜像
- 第二个Dockerfile文件
- 构建镜像
- 查看构建的镜像
6.使用Docker-compose容器编排
6.1安装Docker-compose(高版本的Docker会默认安装)
注意:如果是低版本的compose,docker
和compose
之间要有-
- 首先查看主机是否有docker-compose环境
如果没有就安装docker-compose
- 安装命令
如果是低版本的docker需要安装docker-compose
由于docker-compose是从github上安装的,有可能是安装失败,所以需要那啥,都懂的话
- 查看docker-compose版本
6.2配置nginx文件
- 在/目录下创建一个app目录,进入app目录
- 首先创建一个nginx容器,只是为了复制出配置
6.4编写docker-compose.yml文件
- 在/mydata目录下创建docker-compose.yml文件,并编写docker-compose.yml文件
在vim模式下 :set paste
粘贴的文本数据不会乱
- 检查当前目录下compose.yml文件是否有语法错误
- 启动所有docker-compose服务并后台运行
查看正在运行的容器实例
注意:因为MySQL和Redis还未配置,会出现容器挂掉的情况,这点等待配置过MySql和Redis之后再重启容器实例即可
7.配置MySQL
- 将sql文件传到
/app/mysql/db
目录下(==和MySQL容器实例相同的容器数据卷位置==)
本机Navicat导出sql文件,传送到/app/mysql/db
目录下
- 进入MySQL容器实例
在/var/lib/mysql
目录下查看是否有sql文件
- 登录MySQL
密码就是在docker-compose.yml文件当中进行配置的
- 使用对应的数据库,导入sql文件
- sql数据导入成功
8.配置Redis
- 获取redis对应版本的配置文件
因为docker拉取的redis镜像是没有redis.conf文件的。
因此,就需要我们官网上找一个相对应版本的的redis.conf配置文件
redis配置文件官网Redis configuration | Redis
因为我的redis版本是6.0.8,所以我选择6.0.的配置文件
- 进入
/app/redis
目录下
不知为何docker-compose.yml文件写的没有问题,但是这里创建的redis.conf文件却是一个文件夹,无奈只好删除redis.conf目录,创建一个redis.conf文件
使用vim命令进入vim编辑器,将redis配置文件内容粘贴进去
在vim模式下 :set paste
粘贴的文本数据不会乱
- 修改配置文件内容
使用/
进行搜索
- ==添加redis密码(requirepass)==
- ==修改bind为0.0.0.0(任何机器都能够访问)==
- ==为了避免和docker中的-d参数冲突,将后台启动设置为no(daemonize no)==
- ==关闭保护模式(protected-mode no)==
9.测试后端接口
- 重启现在未启动的容器实例
- 使用ApiFox进行接口测试(postman也可以)
==测试通过==
- 将已经打包好的前端项目放到本地Nginx里面测试
- 将dist文件直接放到html目录下
- 在conf文件中修改nginx.conf文件,在
http{......}
中添加内容如下
- 点击nginx.exe运行nginx服务
- 访问对应的ip+端口号
如果你的后台出现问题:
问题一:访问405,解决方案请看2.3章的第3步
问题二:页面只有/login
和/dashborad
请求,其他页面是空白,解决方案请看2.4章的第6步
==如果没有问题,下面开始Nginx容器配置==
10.配置Nginx
10.1操作dist文件夹
- 将打包好后的两个dist文件夹重命名发送到
/app/nginx/html
目录下
- 修改nginx.conf配置文件
进入conf文件夹下,打开nginx.conf文件
在http{.......}
添加两个server
记得root路径为容器内的dist文件路径
10.项目测试
访问对应ip和端口,查看项目是否有问题
前台
后台
11.将镜像发布到阿里云镜像仓库
不想做这一章的可以忽略
这里主要是将两个后端子模块镜像上传到阿里云镜像仓库
- 再阿里云中点击镜像容器服务,创建个人实例,再点击创建命名空间
- 点击镜像仓库,创建镜像仓库()
- 查看操作镜像仓库操作指南
- 另一个镜像也一样,查看已经创建的仓库和镜像