当前位置:网站首页>spingboot 容器项目完成CICD部署
spingboot 容器项目完成CICD部署
2022-08-05 05:14:00 【爱埋珊瑚海~~】
GitLab+Jenkins+Docker 完成SpringBoot项目的持续集成
部署介绍
传统的项目持续集成,通常由gitlab+jenkins完成项目的持续集成部署。随着容器化技术的日益成熟,很多项目都采用容器化部署管理,本章节则会给大家介绍怎么完成docker项目的持续集成部署
部署架构

部署准备
项目docker化
以springboot项目test-service为例说明,首先需要新建一个Dockerfile文件,内容如下:
FROM java:8
ENV LANG=C.UTF-8
ENV TZ=Asia/Shanghai
ADD test-service.jar app.jar
CMD ["sh","-c","java -Xmx512m -Xms256m -XX:SurvivorRatio=4 -XX:+UseG1GC -XX:MaxGCPauseMillis=50 -jar -XX:InitiatingHeapOccupancyPercent=70 -Xloggc:/var/log/java_gc.log -XX:+PrintGCDetails -XX:+PrintGCDateStamps -XX:+PrintGCTimeStamps app.jar "]
制作生成镜像制品和执行运行容器的脚本
docker images | grep test-service/latest &> /dev/null
if [ $? -ne 0 ]
then
echo "test-service/latest is not existed,we will docker build it!!!"
docker build -t test-service/latest .
else
echo "test-service/latest is existed!!!"
docker rmi -f test-service/latest
docker build -t test-service/latest .
fi
docker ps -a| grep test-service &> /dev/null
if [ $? -ne 0 ]
then
echo "test-service is not up,we will start up it!!!"
docker run -d -p 8099:8099 --name test-service test-service/latest
else
docker rm -f metadata-service
docker run -d -p 8099:8099 --name test-service metadata-service/latest
echo "test-service is up!!!"
fi
Jenkins部署配置
构建环境

其中clean的参数说明如下图所示:
构建配置

执行的脚本如下:
cd /home/data/
rm -rf test-service
mkdir test-service
cp /var/lib/docker/volumes/jenkins_data/_data/workspace/test-service/test-service/target/test-service.jar /home/data/test-service
cp /var/lib/docker/volumes/jenkins_data/_data/workspace/test-service/test-service/Dockerfile /home/data/test-service
cp /var/lib/docker/volumes/jenkins_data/_data/workspace/test-service/test-service/dockerBuild.sh /home/data/test-service
cd /home/data/test-service
chmod -R 777 dockerBuild.sh
./dockerBuild.sh
边栏推荐
猜你喜欢

The fourth back propagation back propagation

第5讲 使用pytorch实现线性回归

OFDM Lecture 16 5 -Discrete Convolution, ISI and ICI on DMT/OFDM Systems

解决端口占用问题

NodeJs接收上传文件并自定义保存路径

Wise Force Deleter强制删除工具

【零基础开发NFT智能合约】如何使用工具自动生成NFT智能合约带白名单可Mint无需写代码

Flink 状态与容错 ( state 和 Fault Tolerance)

怎么更改el-table-column的边框线

flink基本原理及应用场景分析
随机推荐
BFC(Block Formatting Context)
ES6 生成器
day10-字符串作业
02.01-----参数的引用的作用“ & ”
[Go through 11] Random Forest and Feature Engineering
pycharm中调用Matlab配置:No module named ‘matlab.engine‘; ‘matlab‘ is not a package
【记一下1】2022年6月29日 哥和弟 双重痛苦
LeetCode: 1403. Minimum subsequence in non-increasing order [greedy]
解决端口占用问题
Pandas(五)—— 分类数据、读取数据库
redis 持久化
el-table,el-table-column,selection,获取多选选中的数据
redis persistence
The software design experiment four bridge model experiment
CAP+BASE
Flink HA配置
Mesos learning
怎么更改el-table-column的边框线
Xiaobai, you big bulls are lightly abused
基于Flink CDC实现实时数据采集(四)-Sink接口实现