jenkins介绍

jenkins 是一款流行的开源持续集成(continuous integration)工具,广泛用于项目开发,具有自动化构建、测试和部署等功能。官网: jenkins。
jenkins的特征:
开源的 java语言开发持续集成工具,支持持续集成,持续部署。
易于安装部署配置:可通过 yum安装,或下载war包以及通过docker容器等快速实现安装部署,可方便web界面配置管理。
消息通知及测试报告:集成 rss/e-mail通过rss发布构建结果或当构建完成时通过e-mail通知,生成junit/testng测试报告。
分布式构建:支持 jenkins能够让多台计算机一起构建/测试。
文件识别: jenkins能够跟踪哪次构建生成哪些jar,哪次构建使用哪个版本的jar等。
丰富的插件支持:支持扩展插件,你可以开发适合自己团队使用的工具,如 git,svn,maven,docker等。
jenkins安装和持续集成环境配置

1 )首先,开发人员每天进行代码提交,提交到git仓库
2)然后,jenkins作为持续集成工具,使用git工具到git仓库拉取代码到集成服务器,再配合jdk,maven等软件完成代码编译,代码测试与审查,测试,打包等工作,在这个过程中每一步出错,都重新再执行一次整个流程。
3)最后,jenkins把生成的jar或war包分发到测试服务器或者生产服务器,测试人员或用户就可以访问应用。
jenkins环境搭建
jenkins安装配置
1.采用yum方式安装
加入jenkins安装源:
sudo wget -o /etc/yum.repos.d/jenkins.repo https://pkg.jenkins.io/redhat-stable/jenkins.repo --no-check-certificate rpm --import https://pkg.jenkins.io/redhat-stable/jenkins.io.key
执行yum命令安装:
yum -y install jenkins
2.采用rpm安装包方式【推荐】
wget https://repo.huaweicloud.com/jenkins/redhat-stable/jenkins-2.346.3-1.1.noarch.rpm
执行安装:
rpm -ivh jenkins-2.346.3-1.1.noarch.rpm
配置:
修改jenkins配置-添加自己的jdk路径
vim /etc/init.d/jenkins

修改配置文件:
vi /etc/sysconfig/jenkins
修改内容:
# 修改为对应的目标用户, 这里使用的是root $jenkins_user="root" # 服务监听端口 jenkins_port="16060"
目录权限:
chown -r root:root /var/lib/jenkins chown -r root:root /var/cache/jenkins chown -r root:root /var/log/jenkins
启动:
/etc/init.d/jenkins start #启动服务 #其他指令 ./jenkins stop #关闭服务 ./jenkins restart #重启服务
如果启动失败, 出现错误信息:
starting jenkins bash: /usr/bin/java: no such file or directory
创建java环境的软链接:
ln -s /usr/local/jdk/bin/java /usr/bin/java
3.docker安装
拉取镜像
docker pull jenkins/jenkins:lts
创建文件夹
mkdir -p /mydata/jenkins_home chown -r 1000 /mydata/jenkins_home/
运行镜像
docker run -di --name=jenkins -p 8080:8080 -v /mydata/jenkins_home/:/var/jenkins_home jenkins/jenkins:lts
4.管理后台初始化设置
http://192.168.2.4:8080/
需要输入管理密码, 在以下位置查看:
#docker安装 docker logs jenkins #yum安装 cat /var/lib/jenkins/secrets/initialadminpassword

按默认设置,把建议的插件都安装上

这一步等待时间较长, 安装完成之后, 创建管理员用户:

配置访问地址:

配置完成之后, 会进行重启, 之后可以看到管理后台:

jenkins插件安装
在实现持续集成之前, 需要确保以下插件安装成功。
maven integration plugin: maven 集成管理插件。
docker plugin: docker集成插件。
gitlab plugin: gitlab集成插件。
publish over ssh:远程文件发布插件。
ssh: 远程脚本执行插件。
安装方法:
进入【系统管理】-【插件管理】
点击标签页的【可选插件】
在过滤框中搜索插件名称

勾选插件, 点击直接安装即可。
注意,如果没有安装按钮,需要更改配置
在安装插件的高级配置中,修改升级站点的连接为:http://updates.jenkins.io/update-center.jsonhttp://updates.jenkins.io/update-center.jsonhttps://jenkins-zh.gitee.io/update-center-mirror/tsinghua/update-center.json保存
或者从这个网站获取对应jenkins版本的升级站点
index of /jenkins/updates/ | 清华大学开源软件镜像站 | tsinghua open source mirror
然后到jenkins安装服务器上,全局查找
find / -name default.json
找到后,进入文件目录,备份该文件
cp default.json default.json.bak
在同目录下载该文件,并修改文件名为default.json
# 下载 wget https://mirrors.tuna.tsinghua.edu.cn/jenkins/updates/dynamic-stable-2.346.3/update-center.json --no-check-certificate # 改名 mv update-center.json default.json
git安装配置
1.yum 安装方式
yum -y install git
2.采用源码包方式安装
安装依赖包
yum -y install curl-devel expat-devel gettext-devel openssl-devel zlib-devel yum -y install gcc perl-extutils-makemaker
如果之前有安装旧版本, 先做卸载, 没有安装则忽略
yum remove git
下载源码包
cd /usr/local wget https://mirrors.edge.kernel.org/pub/software/scm/git/git-1.8.3.1.tar.gz tar -xvf git-1.8.3.1.tar.gz
也可以安装其他版本, 地址:index of /pub/software/scm/git/
编译安装
cd git-1.8.3.1 make prefix=/usr/local/git all make prefix=/usr/local/git install echo "export path=$path:/usr/local/git/bin" >> /etc/bashrc source /etc/bashrc
3.检查git版本
git version
maven安装配置
1.下载安装包
下载地址: maven – download apache maven
2.解压安装包
cd /usr/local unzip -o apache-maven-3.6.1-bin.zip
上传本地仓库并解压
3.配置
环境变量配置
vi /etc/profile
增加:
export maven_home=/usr/local/maven/apache-maven-3.6.1 export path=$path:$maven_home/bin
如果权限不够,则需要增加当前目录的权限
chmod 777 /usr/local/apache-maven-3.6.1/bin/mvn
修改镜像仓库配置:
vi /usr/local/apache-maven-3.6.1/conf/settings.xml
需要把本机的仓库打包上传到服务器上(不上传会自动下载)
然后指定上传后的仓库配置
jenkins工具配置
进入【系统管理】--> 【全局工具配置】
maven配置全局设置
指定jdk配置
指定maven 目录
指定docker目录
如果不清楚docker的安装的目录,可以使用whereis docker 命令查看docker的安装的目录
ssh配置
进入【系统管理】--> 【凭据】--> 【全局】
添加凭证
进入【系统管理】--> 【系统配置】
配置ssh
持续集成应用
应用集成docker配置
目标:部署的每一个微服务都是先创建docker镜像后创建对应容器启动
方式一:本地微服务打包以后上传到服务器,编写dockerfile文件完成。
方式二:使用dockerfile-maven-plugin插件,可以直接把微服务创建为镜像使用(更省事)
以demo应用为例
<?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.2</version>
</parent>
<groupid>com.example</groupid>
<artifactid>demo</artifactid>
<version>0.0.1-snapshot</version>
<name>demo</name>
<description>demo</description>
<properties>
<docker.image>docker_storage</docker.image>
<java.version>1.8</java.version>
<project.build.sourceencoding>utf-8</project.build.sourceencoding>
<maven.compiler.source>1.8</maven.compiler.source>
<maven.compiler.target>1.8</maven.compiler.target>
</properties>
<build>
<finalname>heima-leadnews-user</finalname>
<plugins>
<plugin>
<groupid>org.springframework.boot</groupid>
<artifactid>spring-boot-maven-plugin</artifactid>
<executions>
<execution>
<goals>
<goal>repackage</goal>
</goals>
</execution>
</executions>
</plugin>
<plugin>
<groupid>org.apache.maven.plugins</groupid>
<artifactid>maven-compiler-plugin</artifactid>
<version>3.7.0</version>
<configuration>
<source>${java.version}</source>
<target>${java.version}</target>
</configuration>
</plugin>
<plugin>
<groupid>com.spotify</groupid>
<artifactid>dockerfile-maven-plugin</artifactid>
<version>1.3.6</version>
<configuration>
<repository>${docker.image}/${project.artifactid}</repository>
<buildargs>
<jar_file>target/${project.build.finalname}.jar</jar_file>
</buildargs>
</configuration>
</plugin>
</plugins>
</build>
</project>
应用集成dockerfile文件
# 设置java版本
from openjdk:8
# 指定存储卷, 任何向/tmp写入的信息都不会记录到容器存储层
volume /tmp
# 拷贝运行jar包
arg jar_file
copy ${jar_file} app.jar
# 设置jvm运行参数, 这里限定下内存大小,减少开销
env java_opts="\
-server \
-xms256m \
-xmx512m \
-xx:metaspacesize=256m \
-xx:maxmetaspacesize=512m"
#空参数,方便创建容器时传参
env params=""
# 入口点, 执行java运行命令
entrypoint ["sh","-c","java -jar $java_opts /app.jar $params"]放到与pom同级
jenkins应用打包配置
以demo应用为例
1.新建任务
2.找到自己指定的git仓库,设置用户名和密码
找到自己指定的git仓库
设置gitee用户和密码
配置gitee
3.执行maven命令
clean install -dmaven.test.skip=true dockerfile:build -f pom.xml
注意:根据自己的实际代码路径配置
- -dmaven.test.skip=true 跳过测试
- dockerfile:build 启动dockerfile插件构建容器
- -f pom.xml 指定需要构建的文件(必须是pom)
4.并执行shell脚本
if [ -n "$(docker ps -a -f name=$job_name --format '{{.id}}' )" ]
then
#删除之前的容器
docker rm -f $(docker ps -a -f name=$job_name --format '{{.id}}' )
fi
# 清理镜像
docker image prune -f
# 启动docker服务
docker run -d --net=host -e params="--spring.profiles.active=prod" --name $job_name docker_storage/$job_name5.执行日志
拉取代码

编译打包

构建镜像

清理容器,创建新的容器

测试
访问应用

jenkins触发器配置
url触发远程构建
触发远程构建,修改jenkins的配置,如下

触发构建url: http://192.168.200.100:16060/job/leadnews-admin/build?token=88888888
其他工程构建后触发
配置需要触发的工程

定时构建
定时构建( build periodically)

定时字符串从左往右分别为: 分 时 日 月 周
定时构建-定时表达式
定时字符串从左往右分别为: 分 时 日 月 周
| 组成部分 | 含义 | 取值范围 |
| 第一部分 | minute (分) | 0~59 |
| 第二部分 | hour(小时) | 0~23 |
| 第三部分 | day(天) | 1~31 |
| 第四部分 | month(月) | 1~12 |
| 第五部分 | week(周) | 0~7,0 和 7 都是表示星期天 |
- 符号h 表示一个随机数
- 符号* 取值范围的任意值
案例:
- 每30分钟构建一次:h/30 * * * * 10:02 10:32
- 每2个小时构建一次: h h/2 * * *
- 每天的8点,12点,22点,一天构建3次: (多个时间点中间用逗号隔开) 0 8,12,22 * * *
- 每天中午12点定时构建一次 h 12 * * *
- 每天下午18点定时构建一次 h 18 * * *
轮询
轮询 scm(poll scm)
轮询scm,是指定时扫描本地代码仓库的代码是否有变更,如果代码有变更就触发项目构建。

jenkins会定时扫描本地整个项目的代码,增大系统的开销,不建议使用。
总结
以上为个人经验,希望能给大家一个参考,也希望大家多多支持代码网。
发表评论