jenkins 自动部署流程实战
概述:
经过前两篇的Jenkins安装和配置,相信很多小伙伴也都做好了Jenkins的准备工作!后面我将会从一个简单的demo出发到部署全流程!
一、准备工作
git搭建好并能上传项目,并能按照上一篇对将git配置到Jenkins中
二、 项目创建
- 项目结构
- pom
<?xml version="1.0" encoding="UTF-8"?>
<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 https://maven.apache.org/xsd/maven-4.0.0.xsd">
<modelVersion>4.0.0</modelVersion>
<parent>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-parent</artifactId>
<version>2.4.0</version>
<relativePath/> <!-- lookup parent from repository -->
</parent>
<groupId>com.spring</groupId>
<artifactId>demo</artifactId>
<version>0.0.1-SNAPSHOT</version>
<name>demo</name>
<description>Demo project for Spring Boot</description>
<properties>
<java.version>1.8</java.version>
</properties>
<dependencies>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-web</artifactId>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-test</artifactId>
<scope>test</scope>
</dependency>
</dependencies>
<build>
<plugins>
<plugin>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-maven-plugin</artifactId>
</plugin>
</plugins>
</build>
</project>
- Dockerfile
FROM openjdk:8-jre
MAINTAINER llong <6959xxxxx@qq.com>
RUN mkdir /app
COPY ./target/demo-0.0.1-SNAPSHOT.jar /app/app.jar
EXPOSE 8081
ENTRYPOINT ["java", "-jar", "/app/app.jar", "--spring.profiles.active=test", "--server.port=8081", "> /app/app.log"]
三 、git标签
由于我们生产中部署要出了问题,是要实现版本快速回滚的!所以我们在大版本跟新时候,都要打tag标签!这里可以修改对应的输出语句来查看版本回滚的效果!
可以在idea中打,也可以在git中打,这里我截图大致说明下
四、4. Jenkins创建项目第一次构建
- 创建一个自由风格的项目
- 配置git完成第一次构建
- 点击立即构建,查看工作空间发现项目已经拉下来了!这样在项目目录结构没有改变的情况下,我们都没有必要一直重复拉取我们的代码!
五 、正式配置构建过程
- 关闭源码管理
- 配置丢弃旧构建,这个配置看自己,一般我保留十次构建
- 配置参数话构建过程
这里使用了 Groovy 脚本来查询最近的 tags 版本,代码如下:
def ver_keys = [ 'bash', '-c', 'cd /var/jenkins_home/workspace/demo;git pull>/dev/null; git remote prune origin >/dev/null; git tag -l|sort -r |head -10 ' ]
ver_keys.execute().text.tokenize('\n')
- 增加构建步骤
echo $RELEASE_VERSION
cd /var/jenkins_home/workspace/demo
git checkout $RELEASE_VERSION
git pull origin $RELEASE_VERSION
mvn clean install
- 保存后,去到项目中点击构建,提示这个警告不要慌,是说你的Groovy 脚本需要你同意认证一下
你点击同意后发现tag出来了,就说明成功了!到这里也说明持续集成成功了,后面完成持续部署!
六、持续部署
上一篇配置中讲到我们一般是部署到另外一台服务器,所以部署前请根据上一篇配置,连接好我们需要部署项目的服务器!然后项目构建中的配置如下
cd /usr/local/jenkins/demo
cp docker/Dockerfile .
docker build -t mydemo .
docker-compose down
docker-compose up -d
docker image prune -f
去到对应服务器上创建docker-compose.yml
version: '3.1'
services:
mydemo:
image: mydemo
container_name: mydemo
ports:
- 8081:8081
大家也可以写在项目中的docker文件下带过去执行!
到这里所有持续集成和部署的步骤就全部结束了步骤有点多,初学者建议大家一个模块个模块的测试!
七、测试
点击构建进行测试!
可以根据日志来找出对应问题,成功后输入自己项目中的接口测试!
测试成功了,根据自己tag的版本,接口输出对应的内容!
后记
大家搭建完全流程有没有觉得有什么问题?每次都要打包编译和构建镜像显的十分繁琐,即使版本回退,也要重新构建镜像!使得回退版本显得很慢,而且也违背docker使用初衷!在针对更大企业的时候,maven其实是支持docker的,我们后期可以搭建镜像私库,版本回退时候,直接回退镜像版本!