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://img-blog.csdnimg.cn/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://img-blog.csdnimg.cn/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端口,发现访问成功!

  • 13
    点赞
  • 61
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
SpringBoot是一个非常流行的Java Web开发框架,而MyBatis则是Java开发中常用的ORM框架。在实际项目中,我们常常需要将两者结合起来使用。本文将为大家提供一个保姆教程,详细讲解SpringBoot如何集成MyBatis。 一、引入相关依赖 在SpringBoot中集成MyBatis,需要在pom.xml文件中引入相关依赖。具体的依赖如下: <!-- MyBatis依赖 --> <dependency> <groupId>org.mybatis.spring.boot</groupId> <artifactId>mybatis-spring-boot-starter</artifactId> <version>2.1.1</version> </dependency> <!-- 数据库驱动依赖 --> <dependency> <groupId>com.h2database</groupId> <artifactId>h2</artifactId> <version>1.4.200</version> </dependency> 二、配置数据源 在集成MyBatis之前,需要先配置数据源。可以在application.yml文件中添加如下配置: # 数据库配置 spring: datasource: url: jdbc:h2:file:./data/test;DB_CLOSE_ON_EXIT=FALSE username: sa password: driver-class-name: org.h2.Driver 这里使用了h2数据库,并指定了特定的路径和用户名、密码。 三、配置Mapper 接下来需要配置Mapper。在创建Mapper之前,需要先创建Java实体类。例如,可以创建一个User实体类: public class User { private Integer id; private String name; private Integer age; /* 省略setter和getter方法 */ } 然后,可以创建对应的Mapper: @Mapper public interface UserMapper { @Select("select * from user where id = #{id}") User selectUserById(Integer id); @Insert("insert into user(name, age) values(#{name}, #{age})") int insertUser(User user); @Delete("delete from user where id = #{id}") int deleteUser(Integer id); @Update("update user set name = #{name}, age = #{age} where id = #{id}") int updateUser(User user); } 在这里我们使用了注解方式对Mapper进行配置。 四、配置MyBatis 在使用MyBatis之前,需要先进行配置。在application.yml文件中添加如下配置: # MyBatis配置 mybatis: mapper-locations: classpath:mapper/*.xml type-aliases-package: com.example.springbootmybatis.entity 这里指定了Mapper的XML文件位置和Java实体类所在的包路径。 五、在Controller中使用Mapper 最后,可以在Controller中使用Mapper。例如: @RestController public class UserController { @Autowired private UserMapper userMapper; @GetMapping("/user/{id}") public User selectUserById(@PathVariable("id") Integer id) { return userMapper.selectUserById(id); } @PostMapping("/user") public int insertUser(@RequestBody User user) { return userMapper.insertUser(user); } @DeleteMapping("/user/{id}") public int deleteUserById(@PathVariable("id") Integer id) { return userMapper.deleteUser(id); } @PutMapping("/user") public int updateUser(@RequestBody User user){ return userMapper.updateUser(user); } } 这里@Autowired注解注入了UserMapper,然后我们可以在方法中调用UserMapper的方法。 通过以上步骤,我们就成功地将MyBatis集成进了SpringBoot。在实际项目中,可以根据需要修改和扩展上述内容。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

程序员楠瓜

赠人玫瑰,手有余香!

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值