Jenkins+Docker自动化部署

SpringBoot应用打包Docker镜像都是可以通过Maven插件来实现的,但由于远程服务器需要开发2375端口,存在一定的安全隐患。介绍另一种方法,使用DockerFile+Jar+自动化脚本的形式来部署。

项目打包

我们不使用Docker的Maven插件来打包,先在pom.xml中注释掉它

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
<build>
<plugins>
<plugin>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-maven-plugin</artifactId>
</plugin>
<!-- <plugin>-->
<!-- <groupId>com.spotify</groupId>-->
<!-- <artifactId>docker-maven-plugin</artifactId>-->
<!-- <version>1.1.0</version>-->
<!-- <executions>-->
<!-- <execution>-->
<!-- <id>build-image</id>-->
<!-- <phase>package</phase>-->
<!-- <goals>-->
<!-- <goal>build</goal>-->
<!-- </goals>-->
<!-- </execution>-->
<!-- </executions>-->
<!-- <configuration>-->
<!-- <imageName>mall-tiny/${project.artifactId}:${project.version}</imageName>-->
<!-- <dockerHost>http://192.168.6.132:2375</dockerHost>-->
<!-- <baseImage>java:8</baseImage>-->
<!-- <entryPoint>["java", "-jar","/${project.build.finalName}.jar"]-->
<!-- </entryPoint>-->
<!-- <resources>-->
<!-- <resource>-->
<!-- <targetPath>/</targetPath>-->
<!-- <directory>${project.build.directory}</directory>-->
<!-- <include>${project.build.finalName}.jar</include>-->
<!-- </resource>-->
<!-- </resources>-->
<!-- </configuration>-->
<!-- </plugin>-->
</plugins>
</build>

然后使用Maven的package命令直接将应用打成Jar包

此时在target目录下就会生成一个Jar包,我们打包Docker镜像的时候会用到它

DockerFile

主要是定义了如何将Jar包打包成Docker镜像,具体内容如下。

1
2
3
4
5
6
7
8
9
10
# 该镜像需要依赖的基础镜像
FROM java:8
# 将当前目录下的jar包复制到docker容器的/目录下
ADD mall-tiny-jenkins-1.0-SNAPSHOT.jar /mall-tiny-jenkins-1.0-SNAPSHOT.jar
# 声明服务运行在8088端口
EXPOSE 8088
# 指定docker容器启动时运行jar包
ENTRYPOINT ["java", "-jar","/mall-tiny-jenkins-1.0-SNAPSHOT.jar"]
# 指定维护者的名字
MAINTAINER Joe.Ye

自动化脚本

可以作为通用脚本来使用的模板脚本,只需改变其中的一些参数即可,具体执行流程为:停止旧服务->删除旧容器->删除旧镜像->打包新镜像->运行新镜像

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
#!/usr/bin/env bash
# 定义应用组名
group_name='mall-tiny'
# 定义应用名称
app_name='mall-tiny-jenkins'
# 定义应用版本
app_version='1.0-SNAPSHOT'
# 定义应用环境
profile_active='qa'
echo '----copy jar----'
docker stop ${app_name}
echo '----stop container----'
docker rm ${app_name}
echo '----rm container----'
docker rmi ${group_name}/${app_name}:${app_version}
echo '----rm image----'
# 打包编译docker镜像
docker build -t ${group_name}/${app_name}:${app_version} .
echo '----build image----'
docker run -p 8088:8088 --name ${app_name} \
--link mysql:db \
-e 'spring.profiles.active'=${profile_active} \
-e TZ="Asia/Shanghai" \
-v /etc/localtime:/etc/localtime \
-v /mydata/app/${app_name}/logs:/var/logs \
-d ${group_name}/${app_name}:${app_version}
echo '----start container----'

下面讲下自动化脚本里面值得注意的地方:

  • group_nameapp_nameapp_version可以用来定义打包镜像的属性
  • profile_active可以让你的应用使用不同环境下的配置,比如使用qa可以启用测试环境的配置,使用prod可以启用生产环境配置,真正的一包多用
  • docker rmi这步一定要有,如果不删除旧镜像,当新镜像打包的时候会产生none镜像
  • docker run命令中的-e TZ="Asia/Shanghai"时区一定要设置,否则容器时间会和宿主机会相差8个小时

部署运行

直接上传我们的应用Jar包、DockerFile文件和自动化部署脚本到指定目录下:

1
2
3
Dockerfile
mall-tiny-jenkins-1.0-SNAPSHOT.jar
run.sh

Dockerfile文件:

1
2
3
4
5
6
7
8
9
10
11
12
# 该镜像需要依赖的基础镜像
FROM java:8
# 将当前目录下的jar包复制到docker容器的/目录下
ADD mall-tiny-docker-jenkins-1.0-SNAPSHOT.jar /mall-tiny-docker-jenkins.jar
# 运行过程中创建一个mall-tiny-docker-jenkins.jar文件
RUN bash -c 'touch /mall-tiny-docker-jenkins.jar'
# 声明服务运行在8080端口
EXPOSE 8080
# 指定docker容器启动时运行jar包
ENTRYPOINT ["java", "-jar","/mall-tiny-docker-jenkins.jar"]
# 指定维护者的名字
MAINTAINER Joe.Ye

将自动化脚本修改为可执行:

1
chmod +x run.sh

使用./run.sh命令直接运行脚本即可

结合Jenkins自动化部署

推荐安装Publish Over SSH这款Jenkins插件,它的主要作用是可以通过SSH在不同服务器之间传输文件和执行命令。比如说我们把Jenkins装在了测试服务器上,我们可以使用Jenkins在测试服务器上从Git仓库获取代码,然后打成Jar包。打包完成后我们可以通过这个插件将Jar包传输到正式服务器上去,然后执行正式服务器上的自动化脚本,从而实现正式服务器上的自动化部署。

首先我们可以在系统管理->插件管理中找到该插件,然后进行安装

然后在系统管理->插件管理中添加相应的SSH配置

配置完成后创建一个应用的构建任务,在构建这一步中,添加构建步骤为通过SSH发送文件并执行命令

配置好我们的SSH Publisher,主要是源文件路径和目标文件路径,以及需要执行的脚本

1
2
3
4
5
6
7
Source files: target/mall-tiny-jenkins-1.0-SNAPSHOT.jar
Remove prefix files: target
Remote directory: /
Exec command:

cd /mydata/deploy
./run.sh

Powered by AppBlog.CN     浙ICP备14037229号

Copyright © 2012 - 2021 APP开发技术博客 All Rights Reserved.

访客数 : | 访问量 :