Jenkins+Docker自动化部署
SpringBoot应用打包Docker镜像都是可以通过Maven插件来实现的,但由于远程服务器需要开发2375端口,存在一定的安全隐患。介绍另一种方法,使用DockerFile+Jar+自动化脚本的形式来部署。
项目打包
我们不使用Docker的Maven插件来打包,先在pom.xml
中注释掉它
<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镜像,具体内容如下。
# 该镜像需要依赖的基础镜像
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
自动化脚本
可以作为通用脚本来使用的模板脚本,只需改变其中的一些参数即可,具体执行流程为:停止旧服务->删除旧容器->删除旧镜像->打包新镜像->运行新镜像
#!/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_name
、app_name
、app_version
可以用来定义打包镜像的属性profile_active
可以让你的应用使用不同环境下的配置,比如使用qa
可以启用测试环境的配置,使用prod
可以启用生产环境配置,真正的一包多用docker rmi
这步一定要有,如果不删除旧镜像,当新镜像打包的时候会产生none
镜像docker run
命令中的-e TZ="Asia/Shanghai"
时区一定要设置,否则容器时间会和宿主机会相差8个小时
部署运行
直接上传我们的应用Jar包、DockerFile文件和自动化部署脚本到指定目录下:
Dockerfile
mall-tiny-jenkins-1.0-SNAPSHOT.jar
run.sh
Dockerfile文件:
# 该镜像需要依赖的基础镜像
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
将自动化脚本修改为可执行:
chmod +x run.sh
使用./run.sh
命令直接运行脚本即可
结合Jenkins自动化部署
推荐安装Publish Over SSH
这款Jenkins插件,它的主要作用是可以通过SSH在不同服务器之间传输文件和执行命令。比如说我们把Jenkins装在了测试服务器上,我们可以使用Jenkins在测试服务器上从Git仓库获取代码,然后打成Jar包。打包完成后我们可以通过这个插件将Jar包传输到正式服务器上去,然后执行正式服务器上的自动化脚本,从而实现正式服务器上的自动化部署。
首先我们可以在系统管理
->插件管理
中找到该插件,然后进行安装
然后在系统管理
->插件管理
中添加相应的SSH配置
配置完成后创建一个应用的构建任务,在构建
这一步中,添加构建步骤为通过SSH发送文件并执行命令
配置好我们的SSH Publisher
,主要是源文件路径和目标文件路径,以及需要执行的脚本
Source files: target/mall-tiny-jenkins-1.0-SNAPSHOT.jar
Remove prefix files: target
Remote directory: /
Exec command:
cd /mydata/deploy
./run.sh
版权声明:
作者:Joe.Ye
链接:https://www.appblog.cn/index.php/2023/04/01/jenkins-docker-automated-deployment/
来源:APP全栈技术分享
文章版权归作者所有,未经允许请勿转载。
共有 0 条评论