SpringBoot 多模块项目打包部署保姆级教程

本文涉及的产品
云数据库 RDS MySQL,集群系列 2核4GB
推荐场景:
搭建个人博客
RDS MySQL Serverless 基础系列,0.5-2RCU 50GB
云数据库 Tair(兼容Redis),内存型 2GB
简介: SpringBoot 多模块项目打包部署保姆级教程

SpringBoot 多模块项目打包部署教程!

SpringBoot 多模块项目打包部署教程!

首先,使用docker安装环境配置(jdk安装不再展示)。

此次部署使用到的技术栈有redis以及mysql,技术不多,但也够吃一桌。

1、环境准备

# 1.安装docker
# 2.docker使用测试
# 3.使用docker安装Mysql
# 4.使用docker安装redis

1-1、安装docker(Vm或服务器)

#1.需要的安装包
yum install -y yum-utils
#2.设置 阿里云 镜像的仓库
yum-config-manager \
    --add-repo \
    https://mirrors.aliyun.com/docker-ce/linux/centos/docker-ce.repo
#3.更新yum软件包索引
yum makecache fast
#4.安装docker docker-ce 社区版  docker-ee 企业版
yum install docker-ce dokcer-ce-cli containerd.io
#5.启动docker
systemctl start docker
#6.查看docker 版本
docker version
#7.配置阿里云加速镜像
vim /etc/docker/daemon.json
# 7.1 添加如下内容,具体地址自己申请咯
# 创建文件夹
mkdir -p /etc/docker
vim /etc/docker/daemon.json
{
  "registry-mirrors": ["https://****.mirror.aliyuncs.com"]
}
# 7.2重启服务
systemctl daemon-reload
systemctl restart docke

1-2、docker使用测试

拉取hello-world镜像 ( docker pull hello-world)

![](https://ucc.alicdn.com/images/user-upload-01/ef4844eab9b443ceb478c2b01540ebc6.png
当拉取成功说明docker环境已经安装成功!

1-3、使用docker安装Mysql

拉取Mysql镜像

docker pull mysql:8.0.16 ==> docker pull 镜像名称:镜像版本
在这里插入图片描述

docker images

查看所有镜像我们发现mysql已经拉取成功了!
在这里插入图片描述

启动并挂载镜像
-d: 后台运行容器,也可以使用镜像id
-p 将容器的端口映射到本机的端口
-v 将主机目录挂载到容器的目录
-e 设置参数  MYSQL_ROOT_PASSWORD 指定登录密码

 docker run -d --name mysql -p 3306:3306 -v /opt/containerd/mysql/conf:/etc/mysql/conf.d -v /opt/containerd/mysql/data:/var/lib/mysql -e MYSQL_ROOT_PASSWORD=123456 mysql:8.0.16

在这里插入图片描述

我们发现mysql容器已经启动成功!

进入容器内部查看
docker exec -it 88ea62512549 /bin/bash  ==> docker exec -it 容器id /bin/bash

![在这里插入图片描述](https://ucc.alicdn.com/images/user-upload-01/4b70bf58b1c6474ab870559e426d417a.png

进入之后我们可以登陆mysql查看:
在这里插入图片描述
我们发现mysql已经可以正常登陆了。

退出容器内部但不停止容器运行

Ctrl+P+Q  退出容器内部但不停止容器运行
exit     退出容器内部并停止容器运行
最后我们使用 navicat 远程连接测试

我们找到我们服务器或者虚拟机的ip地址来连接我们的mysql,
如果使用的是mysql记得放行3306端口,关于如何放行这里不做赘述。
在这里插入图片描述
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-yuDclx4u-1631194979190)(../_resources/889d2b84bf9b423a826c5466916f843d.png)]
在这里插入图片描述
我们发现已经远程连接成功了。

有的小伙伴会问了,谁知道到底有没有成功,mysql都有这个几个数据库啊!

那我们直接在连接到的mysql中新加一个数据库看看docker容器中的mysql是否会出现这个表不就行了吗。

我在mysql中新建了一个blog数据库。
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-we3T81sq-1631194979194)(../_resources/e34689ddec064e4fbe19a580d258e770.png)]
我们重新进入docker容器中,登陆MySQL查看。
在这里插入图片描述
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-ETqo9Z6f-1631194979197)(../_resources/ebf3c529cbdf4a178202de00f25eec28.png)]在这里插入图片描述
这下我们发现确实多了一个blog数据库,这就可以说明我们mysql服务已经成功了!

1-4、docker安装redis

拉取 redis镜像
[root@VM-8-3-centos /]# docker pull redis
Using default tag: latest
latest: Pulling from library/redis
a330b6cecb98: Pull complete 
14bfbab96d75: Pull complete 
8b3e2d14a955: Pull complete 
5da5e1b21a2f: Pull complete 
6af3a5ca4596: Pull complete 
4f9efe5b47a5: Pull complete 
Digest: sha256:e595e79c05c7690f50ef0136acc9d932d65d8b2ce7915d26a68ca3fb41a7db61
Status: Downloaded newer image for redis:latest
docker.io/library/redis:latest
[root@VM-8-3-centos /]# docker images
REPOSITORY   TAG       IMAGE ID       CREATED       SIZE
redis        latest    02c7f2054405   5 days ago    105MB
mysql        8.0.16    de764ad211de   2 years ago   443MB
运行 redis镜像

docker run --name redis -p 6379:6379 -d redis redis-server --appendonly yes

#  -p:端口映射
#  -d:后台运行
#  redis-server --appendonly yes:开启缓存模式,可以存储至硬盘中

[root@VM-8-3-centos /]# docker run --name redis -p 6379:6379 -d redis redis-server --appendonly yes
364d58c2b983d92d0cb14359c8176296f806277dffbc0509a07004f7e585ca38
[root@VM-8-3-centos /]# docker ps
CONTAINER ID   IMAGE          COMMAND                  CREATED         STATUS         PORTS                                                  NAMES
364d58c2b983   redis          "docker-entrypoint.s…"   2 minutes ago   Up 2 minutes   0.0.0.0:6379->6379/tcp, :::6379->6379/tcp              redis
88ea62512549   mysql:8.0.16   "docker-entrypoint.s…"   7 hours ago     Up 7 hours     0.0.0.0:3306->3306/tcp, :::3306->3306/tcp, 33060/tcp   mysql
测试reids

我们使用给可视化工具连接redis,这里我使用的是Reids Desktop Manger,大家感兴趣的可以去下载!

在这里插入图片描述
我们host填写我们的ip地址,服务器要去放行6379端口。由于没有设置密码,我们只需要填写ip和端口即可,端口我们使用的默认的6379。
在这里插入图片描述
这里报错显示连接错误是因为服务器没有开放对应端口,我们去开放端口(这里使用的是腾讯云,阿里云则是去开放安全组)然后再进行连接。
在这里插入图片描述
在这里我们放通了6379端口再进行测试

这次我们发现已经成功连接了。

2、SpringBoot 多模块项目打包

# 1.修改配置文件
# 2.打包项目

2-1、修改配置文件

我们修改ip为参数,因为我们在项目部署之后不可能再去修改我们的源代码了。假设redis出现问题需要更换,我们不可能再去修改ip,所以我们使用参数来进代替,在docker中使用--link进行容器的关联即可。
不再才用上述方法,会有小问题,大家直接使用ip地址即可。

2-2、打包项目

很明显我的项目是分有五个模块的,我们在对多模块进行打包时只需要拿取web模块的jar包即可。(其他模块是直接者间接依赖于web模块,具体请自行百度)
在这里插入图片描述

所以我们需要对web的pom进行一定的配置

我们需要在web模块的pom添加这一段配置信息

  <!--多模块打包:只需在启动类所在模块的POM文件:指定打包插件 -->
    <build>
        <plugins>
            <plugin>
                <!--该插件主要用途:构建可执行的JAR -->
                <groupId>org.springframework.boot</groupId>
                <artifactId>spring-boot-maven-plugin</artifactId>
                <version>2.0.1.RELEASE</version>
                <executions>
                    <execution>
                        <goals>
                            <goal>repackage</goal>
                        </goals>
                    </execution>
                </executions>
            </plugin>
        </plugins>
    </build>

打开右边侧边栏的依赖管理,找到父工程项目。首先进行 clean ,之后进行 package。

在这里插入图片描述

我们去web目录下的target中找到jar文件

我把他拷贝出来换了个名字

我们可以在cmd中 使用 java -jar 命令来运行jar包

但是我们会发现服务是后台接口是无法请求的,因为我们的mysql和redis是有连接成功的。

3、项目部署

# 1.我们使用fxtp将jar包上传到服务器中
# 2.编写Dockerfile
# 3.构建镜像
# 4.运行镜像

3-1、上传至服务器

3-2、编写Dockerfile

# Dicckerfile 必须和jar包在同一目录下
[root@VM-8-3-centos blog]# vim Dockerfile

FROM java:8
EXPOSE 9999

VOLUME /tmp

ENV TZ=Asia/Shanghai
RUN ln -sf /usr/share/zoneinfo/{TZ} /etc/localhosttime && echo "{TZ}" > /etc/timezone

ADD nanjustar-blog.jar /app.jar
RUN bash -c 'touch /app.jar'
ENTRYPOINT ["java","-jar","/app.jar"]

# FROM java:8:表示基于 Jdk8 环境
# EXPOSE 9999:表示对外暴露端口
# VOLUME /tmp:表示挂载在/tmp目录下
# RUN bash -c 'touch /app.jar':表示把jar包添加到镜像服务的根目录中并改名app.jar
# ENTRYPOINT ["java","-jar","/app.jar"]:启动命令

3-3、构建镜像

# 构建镜像 注意最后面有一个点   nanjustar为我自定义的镜像名称
docker build  -t nanjustar .

 ---> d23bdf5b1b1b
Step 2/8 : EXPOSE 9999
 ---> Running in 430864c569e2
Removing intermediate container 430864c569e2
 ---> 864d4b4fcea6
Step 3/8 : VOLUME /tmp
 ---> Running in 8f38028bb40d
Removing intermediate container 8f38028bb40d
 ---> 9e4b8cdf46cc
Step 4/8 : ENV TZ=Asia/Shanghai
 ---> Running in e5f60c461868
Removing intermediate container e5f60c461868
 ---> b29a70fda153
Step 5/8 : RUN ln -sf /usr/share/zoneinfo/{TZ} /etc/localhosttime && echo "{TZ}" > /etc/timezone
 ---> Running in 665b55ef516a
Removing intermediate container 665b55ef516a
 ---> e8308e6135f5
Step 6/8 : ADD nanjustar-blog.jar /app.jar
 ---> a8e790d4947c
Step 7/8 : RUN bash -c 'touch /app.jar'
 ---> Running in ca502827bef2
Removing intermediate container ca502827bef2
 ---> ad8adf1e502b
Step 8/8 : ENTRYPOINT ["java","-jar","/app.jar"]
 ---> Running in 195e052a56b4
Removing intermediate container 195e052a56b4
 ---> 786a2d1157a4
Successfully built 786a2d1157a4
Successfully tagged nanjustar:latest

# 镜像构建完成,使用 docker images 查看
[root@VM-8-3-centos blog]# docker images
REPOSITORY   TAG       IMAGE ID       CREATED          SIZE
nanjustar    latest    786a2d1157a4   52 seconds ago   759MB
redis        latest    02c7f2054405   6 days ago       105MB
mysql        8.0.16    de764ad211de   2 years ago      443MB
java         8         d23bdf5b1b1b   4 years ago      643MB

3-4、运行镜像

#运行镜像 --link 镜像名:参数名
docker run --name nanjublog -p 9999:9999 -d nanjustar
cc472a4a22815b79e77f5e112393dc23596ae7cba7d4b3ecbde674683ac217a4


# docker ps 我们会发现我们的镜像已经跑起来了
[root@VM-8-3-centos blog]# docker ps
CONTAINER ID   IMAGE          COMMAND                  CREATED          STATUS          PORTS                                                  NAMES
cc472a4a2281   nanjustar      "java -jar /app.jar"     41 seconds ago   Up 40 seconds   0.0.0.0:9999->9999/tcp, :::9999->9999/tcp              nanjublog
364d58c2b983   redis          "docker-entrypoint.s…"   53 minutes ago   Up 53 minutes   0.0.0.0:6379->6379/tcp, :::6379->6379/tcp              redis
88ea62512549   mysql:8.0.16   "docker-entrypoint.s…"   8 hours ago      Up 8 hours      0.0.0.0:3306->3306/tcp, :::3306->3306/tcp, 33060/tcp   mysql

最后我们通过ip访问9999端口,发现访问成功!

相关实践学习
基于Redis实现在线游戏积分排行榜
本场景将介绍如何基于Redis数据库实现在线游戏中的游戏玩家积分排行榜功能。
云数据库 Redis 版使用教程
云数据库Redis版是兼容Redis协议标准的、提供持久化的内存数据库服务,基于高可靠双机热备架构及可无缝扩展的集群架构,满足高读写性能场景及容量需弹性变配的业务需求。 产品详情:https://www.aliyun.com/product/kvstore &nbsp; &nbsp; ------------------------------------------------------------------------- 阿里云数据库体验:数据库上云实战 开发者云会免费提供一台带自建MySQL的源数据库&nbsp;ECS 实例和一台目标数据库&nbsp;RDS实例。跟着指引,您可以一步步实现将ECS自建数据库迁移到目标数据库RDS。 点击下方链接,领取免费ECS&amp;RDS资源,30分钟完成数据库上云实战!https://developer.aliyun.com/adc/scenario/51eefbd1894e42f6bb9acacadd3f9121?spm=a2c6h.13788135.J_3257954370.9.4ba85f24utseFl
目录
相关文章
|
14天前
|
Java 应用服务中间件
SpringBoot获取项目文件的绝对路径和相对路径
SpringBoot获取项目文件的绝对路径和相对路径
53 1
SpringBoot获取项目文件的绝对路径和相对路径
|
4天前
|
存储 运维 安全
Spring运维之boot项目多环境(yaml 多文件 proerties)及分组管理与开发控制
通过以上措施,可以保证Spring Boot项目的配置管理在专业水准上,并且易于维护和管理,符合搜索引擎收录标准。
15 2
|
9天前
|
分布式计算 关系型数据库 MySQL
SpringBoot项目中mysql字段映射使用JSONObject和JSONArray类型
SpringBoot项目中mysql字段映射使用JSONObject和JSONArray类型 图像处理 光通信 分布式计算 算法语言 信息技术 计算机应用
30 8
|
10天前
|
Dubbo Java 应用服务中间件
深入探讨了“dubbo+nacos+springboot3的native打包成功后运行出现异常”的原因及解决方案
本文深入探讨了“dubbo+nacos+springboot3的native打包成功后运行出现异常”的原因及解决方案。通过检查GraalVM版本兼容性、配置反射列表、使用代理类、检查配置文件、禁用不支持的功能、查看日志文件、使用GraalVM诊断工具和调整GraalVM配置等步骤,帮助开发者快速定位并解决问题,确保服务的正常运行。
26 1
|
16天前
|
JavaScript 前端开发 Java
SpringBoot项目的html页面使用axios进行get post请求
SpringBoot项目的html页面使用axios进行get post请求
40 2
|
16天前
|
前端开发 Java Spring
SpringBoot项目thymeleaf页面支持词条国际化切换
SpringBoot项目thymeleaf页面支持词条国际化切换
45 2
|
16天前
|
JSON Java 数据库
SpringBoot项目使用AOP及自定义注解保存操作日志
SpringBoot项目使用AOP及自定义注解保存操作日志
32 1
|
18天前
|
JavaScript Java 项目管理
Java毕设学习 基于SpringBoot + Vue 的医院管理系统 持续给大家寻找Java毕设学习项目(附源码)
基于SpringBoot + Vue的医院管理系统,涵盖医院、患者、挂号、药物、检查、病床、排班管理和数据分析等功能。开发工具为IDEA和HBuilder X,环境需配置jdk8、Node.js14、MySQL8。文末提供源码下载链接。
|
1月前
|
数据可视化 Java 应用服务中间件
springboot打war包,成功部署
这篇文章介绍了如何将Spring Boot项目打包成WAR文件,并成功部署到Tomcat服务器的详细步骤。
114 0
springboot打war包,成功部署
|
18天前
|
关系型数据库 MySQL Java
SpringBoot项目中mysql字段映射使用JSONObject和JSONArray类型
SpringBoot项目中mysql字段映射使用JSONObject和JSONArray类型
22 0