这篇文章主要介绍了怎么用Jenkins+docker发布Springbot服务的相关知识,内容详细易懂,操作简单快捷,具有一定借鉴价值,相信大家阅读完这篇怎么用Jenkins+docker发布Springbot服务文章都会有所收获,下面我们一起来看看吧。
1.开发Springbot应用
新建多个环境的配置文件
bootstrap.yaml
通过变量获取不同环境active
bootstrap-dev.yml
bootstrap-pre.yaml
预发布及生产环境配置文件走nacos
二.配置docker
新增Dockerfile文件
Dockerfile内容
# Docker image for springboot file run
# VERSION 0.0.1
# Author: eangulee
# 基础镜像使用java
FROM openjdk:8
# 作者
MAINTAINER qql <xxx@qq.com>
# VOLUME 指定了临时文件目录为/tmp。
# 其效果是在主机 /var/lib/docker 目录下创建了一个临时文件,并链接到容器的/tmp
VOLUME /tmp
# 设置时区
ENV TZ=Asia/Shanghai
RUN ln -snf /usr/share/zoneinfo/$TZ /etc/localtime && echo $TZ > /etc/timezone
# 将jar包添加到容器中并更名为app.jar
ARG JAR_FILE
ADD target/cdc-0.0.1-SNAPSHOT.jar /app.jar #替换成你项目打包后的文件名称
#配置项目端口
EXPOSE 8020
# 运行jar包
RUN bash -c 'touch /app.jar'
ENTRYPOINT ["java","-jar","/app.jar","--spring.profiles.active=${env}"] #通过变量传递不同的环境
在服务器项目下新增docker-composer.yaml文件 ,不要放在代码版本库
version: '3'
services:
project-demo:
container_name: cdcd-demo #自定义容器名称
image: qql/cdcd:0.0.1 #镜像名称
restart: always
environment:
env: dev #环境,不同环境使用不同环境名称
volumes:
# 同步时间
- /etc/localtime:/etc/localtime:ro
# 如果项目有些日志或者写文件,需要同步到宿主机器,也需要定义相应的卷
# - ./data:/etc/project-demo/data
# - ./log:/etc/project-demo/log
ports:
- 8080:8020
三.配置Jenkins
新增部署shell脚本
#!/bin/bash
echo "当前位置"
pwd
mvn clean package -Dmaven.test.skip=true
#切换到项目目录
cd cdc
pwd
#获取最新版本tag
LatestTag=$(git describe --tags `git rev-list --tags --max-count=1`)
echo -e "最新版本tag......"
echo -e "$LatestTag"
echo -e "镜像地址"
#获取本机IP
local_ip=`ifconfig eth0 | grep 'inet' | awk '{print $2}' | sed -e "s/addr://"`
echo ${local_ip}
#制作docker镜像
docker build -f Dockerfile -t qql/cdc:1.0 .
echo "制作成功"
cd ../docker
pwd
#根据docker-composer.yaml文件新建获取重新构建docker容器
docker-compose -f docker-composer.yaml -p cdc up -d
step=1 #间隔的秒数,不能大于60
content=""
for (( i = 0; i < 60; i=(i+step) )); do
status_code=$(curl -I -m 10 -o /dev/null -s -w %{http_code} 127.0.0.1:8080/index/index) #访问服务一个接口验证容器是否启动
echo $status_code
if [ $status_code != 200 ]; then
sleep $step
echo "服务还没有启动,耗时"$i"秒"
else
echo "服务已经启动,耗时"$i"秒"
break
fi
if [ $i == 59 ]; then
echo "启动失败"
exit -1
fi
done
{
docker rmi `docker images | grep none | awk '{print $3}'` && /
} || {
echo 'delete null images error(不需要处理)'
}
保存,则就可以执行部署
执行构建