1、简介
官网: http://jenkins-ci.org
Jenkins 是一款流行的开源持续集成(Continuous Integration)工具,广泛用于项目开发,具有自动化构建、测试和部署等功能。
Jenkins的特征:
- 开源的Java语言开发持续集成工具,支持持续集成,持续部署。
- 易于安装部署配置:可通过yum安装,或下载war包以及通过docker容器等快速实现安装部署,可方便web界面配置管理。
- 消息通知及测试报告:集成RSS/E-mail通过RSS发布构建结果或当构建完成时通过e-mail通知,生成JUnit/TestNG测试报告。名称
- IP地址 安装的软件代码托管服务器。 分布式构建:支持Jenkins能够让多台计算机一起构建/测试。
- 文件识别:Jenkins能够跟踪哪次构建生成哪些jar,哪次构建使用哪个版本的jar等。
- 丰富的插件支持:支持扩展插件,你可以开发适合自己团队使用的工具,如git,svn,maven,docker等
2、安装jenkins
2.1 安装JDK
2.2 获取jenkins安装包
下载页面:https://jenkins.io/zh/download/
安装文件:jenkins-2.282-1.1.noarch.rpm
wget http://mirrors.jenkins-ci.org/redhat/jenkins-2.282-1.1.noarch.rpm
2.3 安装jenkins
rpm -ivh jenkins-2.190.3-1.1.noarch.rpm
或者
yum -y locainstall jenkins-2.190.3-1.1.noarch.rpm
目录结构
/usr/lib/jenkins/jenkins.war #WAR包
/etc/sysconfig/jenkins #配置文件
/var/lib/jenkins/ #默认的JENKINS_HOME目录
/var/log/jenkins/jenkins.log #Jenkins日志文件
2.4 修改Jenkins配置
vim /etc/sysconfig/jenkins
修改内容如下:
JENKINS_USER="root"
JENKINS_PORT="9999"
vim /etc/rc.d/init.d/jenkins
修改内容如下:
candidates="的下一行添加
/usr/local/jdk1.8.0_112/bin/java #java的环境变量
2.5 启动Jenkins
systemctl start jenkins && systemctl enable jenkins
2.6 打开浏览器访问
http://10.99.200.111:9999,因为Jenkins插件需要连接默认官网下载,速度非常慢,而且经过会失败,所以我们暂时先跳过插件安装
3、Jenkins插件管理
Jenkins本身不提供很多功能,我们可以通过使用插件来满足我们的使用。例如从Gitlab拉取代码,使用Maven构建项目等功能需要依靠插件完成。接下来演示如何下载插件。
3.1 修改Jenkins插件下载地址
1)修改默认default.json文件
cd /var/lib/jenkins/updates
sed -i 's#https://updates.jenkins.io/download#https://mirrors.tuna.tsinghua.edu.cn/jenkins#g' default.json
sed -i 's#http://www.google.com#https://www.baidu.com#g' default.json
2)修改插件地址
Jenkins->Manage Jenkins->Manage Plugins,点击Advanced,把Update Site改为国内插件下载地址https://mirrors.tuna.tsinghua.edu.cn/jenkins/updates/update-center.json
,Sumbit后,在浏览器输入:http://10.99.200.111:9999,重启Jenkins即可。
3.2 下载中文汉化插件
1)搜索中文插件并安装
Jenkins->Manage Jenkins->Manage Plugins,点击Available,搜索"Chinese"
2)重启Jenkins后,就看到Jenkins汉化了
3.3 Jenkins用户权限管理
利用Role-based Authorization Strategy 插件来管理Jenkins用户权限
开启权限全局安全配置,授权策略切换为"Role-Based Strategy",保存。
刷新页面即可看到
3.4 创建角色
1)创建角色
在系统管理页面进入 Manage and Assign Roles,点击"Manage Roles",添加相应的角色权限保存即可。
-
Global roles(全局角色):管理员等高级用户可以创建基于全局的角色
-
Project roles(项目角色):针对某个或者某些项目的角色
-
Slave roles(奴隶角色):节点相关的权限
我们添加以下三个角色:baseRole:该角色为全局角色。这个角色需要绑定Overall下面的Read权限,是为了给所有用户绑定最基本的Jenkins访问权限。注意:如果不给后续用户绑定这个角色,会报错误:用户名 ismissing the Overall/Read permission
role1:该角色为项目角色。使用正则表达式绑定"ops.",意思是只能操作ops开头的项目。
role2:该角色也为项目角色。绑定"dev.",意思是只能操作dev开头的项目。
2)创建用户
在系统管理页面进入 Manage Users,点击新建用户
3)给用户分配角色
系统管理页面进入Manage and Assign Roles,点击Assign Roles绑定规则如下:wangkx
用户分别绑定baseRole和role1角色,renlt
用户分别绑定baseRole和role2角色,保存即可。
4)创建项目测试权限
以admin管理员账户创建两个项目,分别为ops-test01和dev-test01
结果为:
wangkx用户登录,只能看到ops-test01项目
renlt用户登录,只能看到dev-test01项目
3.5 Jenkins凭证管理
1)安装Credentials Binding插件
要在Jenkins使用凭证管理功能,需要安装Credentials Binding插件
安装插件后,右边多了"凭证"菜单,在这里管理所有凭证
- Username with password:用户名和密码 SSH Username with private
- key:使用SSH用户和密钥 Secret
- fifile:需要保密的文本文件,使用时Jenkins会将文件复制到一个临时目录中,再将文件路径设置到一个变量中,等构建结束后,所复制的Secret
- fifile就会被删除 Secret text:需要保存的一个加密的文本串,如钉钉机器人或Github的api
- tokenCertifificate:通过上传证书文件的方式
常用的凭证类型有:Username with password
(用户密码)和SSH Username with private key
(SSH密钥)
接下来以使用Git工具到Gitlab拉取项目源码为例,演示Jenkins的如何管理Gitlab的凭证。
2)安装Git插件和Git工具
为了让Jenkins支持从Gitlab拉取源码,需要安装Git插件以及在CentOS7上安装Git工具。
gitlab参考连接
CentOS7上安装Git工具:
yum install git -y #安装
git --version #安装后查看版本
3)用户密码类型
step1:创建凭证Jenkins->凭证->系统->全局凭证->添加凭证->选择"Username with password",输入Gitlab的用户名和密码,点击"确定"。
step2:测试凭证是否可用
在已经创建的项目dev-test01上找到"源码管理"->“Git”,在Repository URL复制Gitlab中的项目URL
这时会报错说无法连接仓库!在Credentials选择刚刚添加的凭证就不报错啦
保存配置后,点击构建"立即构建”,开始构建项目
查看/var/lib/jenkins/workspace/目录,发现已经从Gitlab成功拉取了代码到Jenkins中。
4)SSH密钥类型
SSH免密登录示意图
step1:使用root用户生成公钥和私钥
ssh-keygen -t rsa #在/root/.ssh/目录保存了公钥和使用
id_rsa:私钥文件
id_rsa.pub:公钥文件
step2:把生成的公钥放在Gitlab中
以root账户登录->点击头像->Settings->SSH Keys复制刚才id_rsa.pub文件的内容到这里,点击"Add Key"
step3:在Jenkins中添加凭证,配置私钥
在Jenkins添加一个新的凭证,类型为"SSH Username with private key",把刚才生成私有文件内容复制过来
step4:测试凭证是否
在已经创建的项目ops-test01上找到"源码管理"->“Git”,在Repository URL复制Gitlab中的项目URL,这次要使用Gitlab的SSH连接,并且选择SSH凭证。
gitlab上获取项目的ssh连接
jenkins上ops-test01上测试
保存配置后,点击构建"立即构建”,开始构建项目
查看/var/lib/jenkins/workspace/目录,发现已经从Gitlab成功拉取了代码到Jenkins中。
3.6 Maven安装和配置
在Jenkins集成服务器上,我们需要安装Maven来编译和打包项目。
1)安装Maven(先上传Maven软件到10.99.200.111上)
cd /root/pkg
tar -xf apache-maven-3.6.3-bin.tar.gz -C /usr/local/ #解压
echo 'export MAVEN_HOME=/usr/local/apache-maven-3.6.3' >> /etc/profile
echo 'export PATH=$MAVEN_HOME/bin:$PATH' >> /etc/profile
source /etc/profile #配置生效
mvn -v #查看maven版本
2)全局工具配置关联JDK和Maven
step1:关联jdk和maven
Jenkins->Global Tool Confifiguration->JDK->新增JDK,配置如下:
Jenkins->Global Tool Confifiguration->Maven->新增Maven,配置如下:
step2:添加Jenkins全局变量
Manage Jenkins->Configure System->Global Properties ,添加三个全局变量JAVA_HOME、MAVEN_HOME、PATH+EXTRA
step3:修改Maven的settings.xml
mkdir /usr/local/apache-maven-3.6.3/repo #创建maven的本地仓库
vim /usr/local/apache-maven-3.6.3/conf/settings.xml #分别添加如下配置项
<mirrors>
<id>aliyunmaven</id>
<mirrorOf>central</mirrorOf>
<name>aliyun maven</name>
<url>http://maven.aliyun.com/nexus/content/repositories/central/</url>
</mirrors>
<localRepository>/usr/local/apache-maven-3.6.3/repo</localRepository>
step4:测试Maven是否配置成功
使用之前的gitlab密码测试项目(ops-test01),修改配置
都到这儿了,更多信息,详见个人微信公众号ALL In Linux,来扫一扫吧!