当前位置:网站首页>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
边栏推荐
猜你喜欢

Lecture 5 Using pytorch to implement linear regression

拿出接口数组对象中的所有name值,取出同一个值

flink中文文档-目录v1.4

The fourth back propagation back propagation

vscode要安装的插件

Lecture 3 Gradient Tutorial Gradient Descent and Stochastic Gradient Descent

解决:Unknown column ‘id‘ in ‘where clause‘ 问题

el-pagination左右箭头替换成文字上一页和下一页

【过一下7】全连接神经网络视频第一节的笔记

Using pip to install third-party libraries in Pycharm fails to install: "Non-zero exit code (2)" solution
随机推荐
SQL(一) —— 增删改查
Flink HA安装配置实战
门徒Disciples体系:致力于成为“DAO世界”中的集大成者。
js实现数组去重
ES6基础语法
【过一下6】机器视觉视频 【过一下2被挤掉了】
el-table鼠标移入表格改变显示背景色
Database experiment five backup and recovery
BFC(Block Formatting Context)
Do you use tomatoes to supervise your peers?Add my study room, come on together
【过一下14】自习室的一天
【MySQL】数据库多表链接的查询方式
学习总结week2_3
Flink Distributed Cache 分布式缓存
【过一下3】卷积&图像噪音&边缘&纹理
通过Flink-Sql将Kafka数据写入HDFS
第四讲 反向传播随笔
如何停止flink job
【Over 16】Looking back at July
第四讲 back propagation 反向传播