gitlab+jenkins+docker持续集成环境搭建实战
介绍

什么是持续集成?
持续集成(CI)是在源代码变更后自动检测、拉取、构建和(在大多数情况下)进行单元测试的过程。持续集成是启动管道的环节(尽管某些预验证 —— 通常称为 上线前检查(pre-flight checks) —— 有时会被归在持续集成之前)。
本篇简明扼要,直击痛点,可以让急需构建CI/DI环境而无从下手的小伙伴。

步骤
准备服务器
4台centos7虚拟机:
192.168.182.131 gitlab服务器
192.168.182.132 jenkins服务器
192.168.182.133 java应用发布服务器
192.168.182.134 docker发布服务器
可以先搭建1台基础的包含docker和jdk环境的虚拟机。其余的3台采用克隆方式创建。
准备1个springboot项目
主要用于演示代码提交和自动化构建,代码很简单:
<?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 http://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.5</version>
<relativePath/>
</parent>
<groupId>com.test.java</groupId>
<artifactId>helloci</artifactId>
<version>1.0-SNAPSHOT</version>
<properties>
<java.version>1.8</java.version>
<project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
<!-- 跳过测试 -->
<skipTests>true</skipTests>
</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>
@RestController
public class HelloController {
@GetMapping
public String hello(){
return "hello ci/cd test docker auto build using pipeline";
}
}
搭建docker环境
- centos7如何安装docker请参考:
https://blog.csdn.net/IndexMan/article/details/128495994
搭建gitlab环境
docker方式启动gitlab
请参考:
https://blog.csdn.net/IndexMan/article/details/103319871
rpm方式安装
- 下载rpm
https://mirrors.tuna.tsinghua.edu.cn/gitlab-ce/yum/el7/选一个版本 - 安装
rpm -ivh gitlab-ce-15.7.0-ce.0.el7.x86_64.rpm

- 修改
external_url配置
改成自己的ip,端口自定义。
vim /etc/gitlab/gitlab.rb

- 启动
gitlab-ctl reconfigure
gitlab-ctl restart

- 访问系统
http://192.168.182.131:8009/
注意:我安装的是gitlab15,root用户默认密码存储在一个配置文件中,这个文件在安装24小时后自动删除!

cat /etc/gitlab/initial_root_password

- 修改管理员密码

搭建jenkins环境
安装jdk11
https://www.oracle.com/java/technologies/downloads/#java11
- 安装
rpm -ivh jdk-11.0.17_linux-x64_bin.rpm
java -version
运行jenkins
- 下载
注意:我下载的是最新版本,需要安装jdk11才能运行。
https://get.jenkins.io/war-stable/2.375.1/jenkins.war - 运行
java -jar jenkins.war
记下密码。

- 访问
http://192.168.182.132:8080/
填入管理员密码。

- 解决jenkins离线提示

修改配置文件:
vim /root/.jenkins/hudson.model.UpdateCenter.xml
将其中的地址改为国内可访问地址,

然后重启再次访问:


注意:这一步先停一下,因为jenkins官方插件安装地址是国外的,这个地方我们要换成国内的。去修改配置文件:
# 修改default.json
cd /root/.jenkins/updates
sed -i 's#updates.jenkins.io/download/plugins#mirrors.tuna.tsinghua.edu.cn/jenkins/plugins#g' default.json && sed -i 's#www.google.com#www.baidu.com#g' default.json
- 然后继续安装推荐插件,最后设置管理员账号密码后进入系统首页

安装插件
maven、ssh、auth插件




配置maven
- 官网下载解压到/usr/local/maven
- 配置环境变量
# 配置Maven环境变量
vi /etc/profile
# 在配置文件末尾加上maven路径
# maven
export MAVEN_HOME=/soft/apache-maven-3.8.6
export PATH=$PATH:$MAVEN_HOME/bin
# 使配置文件立即生效
source /etc/profile
- 配置阿里云仓库
<mirror>
<id>alimaven</id>
<mirrorOf>central</mirrorOf>
<name>aliyun maven</name>
<url>http://maven.aliyun.com/nexus/content/groups/public/</url>
</mirror>
安装git
yum install git
构建maven任务

- 添加之前新建好的git项目地址

- 开始构建



构建后发送到测试服务器

- 修改maven任务配置
添加构建后动作:


- 执行构建
- 到测试服务器查看应用已经在后台运行

解决publisher超时
将构建后执行的命令修改一下:
nohup java -jar /home/helloci/helloci-1.0-SNAPSHOT.jar > /tmp/helloci.log 2>&1 &
构建前置清理脚本
在133服务器 /home/helloci目录下新建脚本clear.sh
#!/bin/bash
rm -f helloci*.jar
appname=$1
echo "arg:$1"
# get pid
pid=`ps -ef | grep $1 |grep 'java -jar' | awk '{printf $2}'`
echo $pid
if [ -z $pid ]
then
echo "$appname not start"
else
kill -9 $pid
fi

配置钩子实现自动构建

浏览器输入以下地址测试:
http://192.168.182.132:8080/buildByToken/build?job=helloci&token=123123
发现可以自动触发构建。
- 在gitlab工程中配置
先解除配置本地URL的限制!

在工程上配置webhook


- 测试,再次提交代码
发现jenkins触发了自动构建:


自动化构建docker镜像
手工构建测试
准备一台docker环境服务器:192.168.182.134
将之前打包好的helloci.jar上传到/home目录,并创建一个Dockerfile文件:
FROM openjdk:8
EXPOSE 9001
WORKDIR /root
COPY *.jar /root/app.jar
ENTRYPOINT ["java","-jar","/root/app.jar"]
- 执行构建命令
docker build -t helloci .

- 解决WARNING: IPv4 forwarding is disabled. Networking will not work
echo "net.ipv4.ip_forward=1" >>/usr/lib/sysctl.d/00-system.conf
systemctl restart network && systemctl restart docker
- 运行镜像
docker run -d -p 9001:9001 --name helloci helloci:latest
访问到9001地址,说明构建没问题。
自动化构建
- 创建新jenkins任务
helloci-docker - 配置pre steps

- 配置传输文件动作
将打包好的jar文件和工程根目录下的Dockerfile传输到134服务器的/home路径下。


- 执行构建
查看134服务器上相关构建结果

使用pipeline构建
使用blue ocean ui

- 创建1个测试pipeline item

pipeline {
agent any
stages {
stage('pull code') {
steps {
echo 'pull success.'
}
}
stage('exec build') {
steps {
echo 'build success.'
}
}
}
}

自动打包docker镜像
- 创建1个新的pipeline item
pipeline-docker - 利用片段生成器,生成git拉取代码脚本、发送文件、执行远程服务器命令脚本,填入到流水线 脚本中:

具体脚本如下:
pipeline {
agent any
tools {
maven "maven3"
}
stages {
stage('拉取代码') {
steps {
git branch: 'main', credentialsId: 'gitlab', url: 'http://192.168.182.131:8009/root/helloci.git'
echo 'pull success.'
}
}
stage('构建jar包') {
steps {
// sh "mvn --version"
sh """
mvn clean package
"""
echo 'build success.'
}
}
stage('清理应用服务器'){
steps {
sshPublisher(publishers: [sshPublisherDesc(configName: '134dockerserver', transfers: [sshTransfer(cleanRemote: false, excludes: '', execCommand: '''cd /home
rm -rf *
docker stop helloci
docker rm helloci
docker rmi helloci''', execTimeout: 120000, flatten: false, makeEmptyDirs: false, noDefaultExcludes: false, patternSeparator: '[, ]+', remoteDirectory: '', remoteDirectorySDF: false, removePrefix: '', sourceFiles: '')], usePromotionTimestamp: false, useWorkspaceInPromotion: false, verbose: false)])
echo 'clear success'
}
}
stage('发送文件') {
steps {
sshPublisher(publishers: [sshPublisherDesc(configName: '134dockerserver', transfers: [sshTransfer(cleanRemote: false, excludes: '', execCommand: '', execTimeout: 120000, flatten: false, makeEmptyDirs: false, noDefaultExcludes: false, patternSeparator: '[, ]+', remoteDirectory: '', remoteDirectorySDF: false, removePrefix: 'target', sourceFiles: '**/helloci*.jar'), sshTransfer(cleanRemote: false, excludes: '', execCommand: '''cd /home
docker build -t helloci .
docker run -d -p 9001:9001 --name helloci helloci:latest''', execTimeout: 120000, flatten: false, makeEmptyDirs: false, noDefaultExcludes: false, patternSeparator: '[, ]+', remoteDirectory: '', remoteDirectorySDF: false, removePrefix: '', sourceFiles: '**/Dockerfile')], usePromotionTimestamp: false, useWorkspaceInPromotion: false, verbose: false)])
echo 'build success.'
}
}
}
}
- 执行构建,后访问发现镜像已更新,配置成功!


gitlab+jenkins+docker持续集成环境搭建实战的更多相关文章
- 使用Docker搭建Jenkins+Docker持续集成环境(自动化构建发布部署)
本文介绍如何通过Jenkins的docker镜像从零开始构建一个基于docker镜像的持续集成环境,包含自动化构建.发布到仓库\并部署上线. 0. 前置条件 服务器安装docker,并启动docker ...
- Docker+Jenkins持续集成环境(1)使用Docker搭建Jenkins+Docker持续集成环境
本文介绍如何通过Jenkins的docker镜像从零开始构建一个基于docker镜像的持续集成环境,包含自动化构建.发布到仓库\并部署上线. 0. 前置条件 服务器安装docker,并启动docker ...
- Jenkins+PowerShell持续集成环境搭建(八)邮件通知
1. 默认邮件功能: Jenkins自带的邮件功能比较简单,配置如下: 设置默认发件人地址: 2. Email Extension Plugin 为了能够更加灵活地使用邮件功能,需要安装Email E ...
- Jenkins+PowerShell持续集成环境搭建(七)构建触发器
Jenkins 有三种类型的构建触发器,如下图: Build after other projects are built:在其他项目构建后构建: Build periodically:定时构建: P ...
- Jenkins+PowerShell持续集成环境搭建(四)常用PowerShell命令
0. 修改执行策略 Jenkins执行PowerShell脚本,需要修改其执行策略.以管理员身份运行PowerShell,执行以下脚本: Set-ExecutionPolicy Unrestricte ...
- Jenkins+PowerShell持续集成环境搭建(一)前期准备
0. 系统要求 Windows Server:本文章使用的为Windows Server 2012 JDK:本文章使用为JDK 1.8 Windows PowerShell:本文章使用为PowerSh ...
- Jenkins+PowerShell持续集成环境搭建(六)参数化构建
参数化构建可以应用于动态绑定源码地址等情况. 勾选“This build is parameterized”: 如果需要动态绑定源码地址,参考: 配置完成后构建项目变成:
- Jenkins+PowerShell持续集成环境搭建(五)SSRS项目
部署SSRS项目的原理是使用ReportingService2005类的方法实现rdl文件上传等功能. 上传rdl文件的脚本示例: $username="Victor"; $pas ...
- Jenkins+PowerShell持续集成环境搭建(三)Web项目
1. 新建一个名字为HelloWorld.Web的Freesyle项目: 2. 配置源码管理: 3. 编译配置: 版本:选择MSBuild4 文件:D:\CI\Config\HelloWorld.We ...
- Jenkins+PowerShell持续集成环境搭建(二)控制台项目
1. 新建一个名字为HelloWorld.Console的Freesyle项目: 2. 配置源码管理: 3. 编译配置: 版本:选择MSBuild4 文件:D:\CI\Config\HelloWorl ...
随机推荐
- [转帖]linux中的set -e 与set -o pipefail
https://www.cnblogs.com/xingmuxin/p/8431970.html 1.set -e "Exit immediately if a simple command ...
- [转帖]Springboot配置kafka用户名密码
华为云开发者联盟 Springboot配置kafka用户名密码 Springboot配置kafka用户名密码 SpringBoot配置kafka用户名密码 Springboot配置kafka用户名密码 ...
- [转帖]【Kafka】(二)Kafka去Zookeeper化,kraft模式搭建
1.简介 由于zookeeper慢慢的成了kafka的瓶颈,kafka提出了去zookeeper化的概念,并在2.8版本之后版本都包含了kraft模式,也就是不需要使用zookeeper了,目前这种模 ...
- [转帖]Tomcat maxKeepAliveRequests
https://www.cnblogs.com/turn2i/p/10480088.html 在写这个问题前,其实我是为了分析项目碰到的一个tcp close wait问题.这个问题就不在这里讲了. ...
- 【转帖】《MySQL高级篇》四、索引的存储结构
1. 为什么使用索引 假如给数据使用 二叉树 这样的数据结构进行存储,如下图所示 2.索引及其优缺点 2.1 索引概述 2.2 优点 类似大学图书馆建书目索引,提高数据检索的效率,降低 数据库的 IO ...
- [转帖]shell脚本中$0 $1 $# $@ $* $? $ 的各种符号的意义
概述 shell中有两类字符,一类是普通字符,在Shell中除了本身的字面意思外没有其他特殊意义,即普通纯文本:另一类即元字符,是Shell的保留字符,在Shell中有着特殊的含义. 今天主要介绍一下 ...
- JVM内存配置的再次思考
JVM内存配置的再次思考 摘要 最近研究过不少内存分配相关的处理 今天晚上突然感觉还不是非常系统. 还是想能够细致的在学习一下. 希望能够慢慢的拾遗,提高自己 操作系统内存的使用情况 本文主要想思考l ...
- CentOS确认网口是否插入网线的办法
最近公司的机器存在网络问题, 部分网络总是不通, 比较奇怪. 最近一直想处理好. 第一步: 先查看网口的设备信息 可以使用 ip link show 可以讲网口信息都展示出来. 一般情况下 NO-C ...
- gin启动https支持
gin是一个使用Go语言开发的Web框架,具有运行速度快,分组的路由器,良好的崩溃捕获和错误处理,支持中间件等. 在工作中有时候需要支持https服务,gin可以通过中间件的方式来提供对https的支 ...
- Go 泛型之明确使用时机与泛型实现原理
目录 一.引入 二.何时适合使用泛型? 场景一:编写通用数据结构时 场景二:函数操作的是 Go 原生的容器类型时 场景三:不同类型实现一些方法的逻辑相同时 三.Go 泛型实现原理 Stenciling ...