# Jenkins 运维
环境要求
- JDK:JDK7+,官网推荐是 JDK 8
- Jenkins:2.190.1
# Jenkins 简介
# Jenkins 是什么
Jenkins 是一款开源 CI&CD 软件,用于自动化各种任务,包括构建、测试和部署软件。
Jenkins 支持各种运行方式,可通过系统包、Docker 或者通过一个独立的 Java 程序。
# CI/CD 是什么
CI(Continuous integration,中文意思是持续集成)是一种软件开发时间。持续集成强调开发人员提交了新代码之后,立刻进行构建、(单元)测试。根据测试结果,我们可以确定新代码和原有代码能否正确地集成在一起。借用网络图片对 CI 加以理解。
CD(Continuous Delivery, 中文意思持续交付)是在持续集成的基础上,将集成后的代码部署到更贴近真实运行环境(类生产环境)中。比如,我们完成单元测试后,可以把代码部署到连接数据库的 Staging 环境中更多的测试。如果代码没有问题,可以继续手动部署到生产环境。下图反应的是 CI/CD 的大概工作模式。
# Jenkins 安装
更详细内容请参考:Jenkins 官方安装文档 (opens new window)
# War 包部署
安装步骤如下:
(1)下载并解压到本地
进入官网下载地址 (opens new window),选择合适的版本下载。
我选择的是最新稳定 war 版本 2.89.4:http://mirrors.jenkins.io/war-stable/latest/jenkins.war
我个人喜欢存放在:/opt/software/jenkins
mkdir -p /opt/software/jenkins
wget -O /opt/software/jenkins/jenkins.war http://mirrors.jenkins.io/war-stable/latest/jenkins.wa
(2)启动
如果你和我一样,选择 war 版本,那么你可以将 war 移到 Tomcat 的 webapps 目录下,通过 Tomcat 来启动。
当然,也可以通过 java -jar
方式来启动。
cd /opt/software/jenkins
nohup java -jar jenkins.war --httpPort=8080 >> nohup.out 2>&1 &
# rpm 包部署
(1)下载安装
sudo wget -O /etc/yum.repos.d/jenkins.repo https://pkg.jenkins.io/redhat-stable/jenkins.repo
sudo rpm --import https://pkg.jenkins.io/redhat-stable/jenkins.io.key
yum install jenkins
(2)启动
systemctl start jenkins
# 访问
- 打开浏览器进入链接
http://localhost:8080
. - 按照说明完成安装.
# Jenkins 基本使用
Jenkins 是一个强大的 CI 工具,虽然本身使用 Java 开发,但也能用来做其他语言开发的项目 CI。下面讲解如何使用 Jenkins 创建一个构建任务。
登录 Jenkins, 点击左侧的新建,创建新的构建任务。
跳转到如下界面。任务名称可以自行设定,但需要全局唯一。输入名称后选择构建一个自由风格的软件项目(其他选项不作介绍)。并点击下方的确定按钮即创建了一个构建任务。之后会自动跳转到该 job 的配置页面。
新建自由风格的软件项目
下图是构建任务设置界面,可以看到上方的几个选项**"General", "源码管理", "构建触发器","构建环境", "构建", "构建后操作"**。下面逐一介绍。
# General
General 是构建任务的一些基本配置。名称,描述之类的。
重要配置项:
- Description:对构建任务的描述。
- Discard old builds:服务器资源是有限的,有时候保存了太多的历史构建,会导致 Jenkins 速度变慢,并且服务器硬盘资源也会被占满。当然下方的"保持构建天数" 和 保持构建的最大个数是可以自定义的,需要根据实际情况确定一个合理的值。
点击右方的问号图标可以查看帮助信息。
# Source Code Management
Source Code Management,即源码管理,就是配置你代码的存放位置。
- Git: 支持主流的 Github 和 Gitlab 代码仓库。因我们的研发团队使用的是 gitlab,所以下面我只会对该项进行介绍。
- Repository URL:仓库地址。
- Credentials:凭证。可以使用 HTTP 方式的用户名密码,也可以是 RSA 文件。 但要通过后面的"ADD"按钮添加凭证。
- Branches to build:构建的分支。
*/master
表示 master 分支,也可以设置为其他分支。 - Repository browser:你所使用的代码仓库管理工具,如 Github、Gitlab.
- Subversion:即 SVN,这里不作介绍。
# Build Triggers
Build Triggers,即构建触发器,用于构建任务的触发器。
配置说明:
- Trigger builds remotely (e.g., from scripts):触发远程构建(例如,使用脚本)。该选项会提供一个接口,可以用来在代码层面触发构建。
- Build after other projects are built:该选项意思是"在其他项目构建后再构建"。
- Build periodically:周期性的构建。就是每隔一段时间进行构建。日程表类似 linux crontab 书写格式。如:
H/30 * * * *
,表示每隔 30 分钟进行一次构建。 - **Build when a change is pushed to GitLab:**当有 git push 到 Gitlab 仓库,即触发构建。后面会有一个触发构建的地址,一般被称为 webhooks。需要将这个地址配置到 gitlab 中,webhooks 如何配置后面介绍。这个是常用的构建触发器。
- **Poll SCM:**该选项是配合上面这个选项使用的。当代码仓库发生改动,jenkins 并不知道。需要配置这个选项,周期性的去检查代码仓库是否发生改动。
# Build Environment
Build Environment,即构建环境,配置构建前的一些准备工作,如指定构建工具。
# Build
Build,即构建。
点击下图中的 Add build step 按钮,会弹出一个构建任务菜单,可以根据实际需要来选择。
【说明】
- Copy artifacts from another project:从其他项目获取构建。一般当本任务有上游任务,需要获取上游任务的构件时使用。比如:有个 Java Web 项目,需要依赖于上一个前端构建任务输出的静态文件压缩包。
- Eexcute NodeJS script:执行 Nodejs 脚本。默认支持 nodejs、npm 命令。
- Eexcute shell: 执行 shell 脚本。用于 Linux 环境。
- Execute Windows batch command:执行 batch 脚本。用于 Windows 环境。
- Invoke Ant:Ant 是一款 java 项目构建工具。
- Invoke Gradle script:Gradle 构建项目。
- Invoke top-level Maven targets:Maven 构建项目。
# Post-build Actions
Post-build Actions,即构建后操作,用于构建完本项目的一些后续操作,比如生成相应的代码测试报告。
个人较常用的配置:
- Archive the artifacts:归档构件。
- Build other projects:构建其他项目。
- Trigger parameterized build on other projects:构建其他项目,并传输构建参数。
- Publish JUnit test result report:发布 Junit 测试报告。
- E-mail Notification:邮件通知,构建完成后发邮件到指定的邮箱。
以上配置完成后,点击保存即可。
# 开始构建
如上图所示,一切配置好后,即可点击 Build Now 开始构建。
# 构建结果
- 构建状态
- Successful 蓝色:构建完成,并且被认为是稳定的。
- Unstable 黄色:构建完成,但被认为是不稳定的。
- Failed 红色:构建失败。
- Disable 灰色:构建已禁用
- 构建稳定性
- 构建稳定性用天气表示:晴、晴转多云、多云、小雨、雷阵雨。天气越好表示构建越稳定,反之亦然。
- 构建历史界面
- console output:输出构建的日志信息
# 其他相关配置
# SSH Server 配置
登录 jenkins -> 系统管理 -> 系统设置
配置请看下图:
重要配置:
SSH Servers: 由于 jenkins 服务器公钥文件我已经配置好,所以之后新增 SSH Servers 只需要配置这一项即可。
Name: 自定义,需要全局唯一。
HostName: 主机名,直接用 ip 地址即可。
Username: 新增 Server 的用户名,这里配置的是 root。
Remote Directory: 远程目录。jenkins 服务器发送文件给新增的 server 默认是在这个目录。
# 配置 Gitlab webhooks
在 gitlab 的 project 页面 打开settings,再打开 web hooks 。点击**"ADD WEB HOOK"** 添加 webhook。把之前 jenkins 配置中的那个 url 添加到这里,添加完成后,点击**"TEST HOOK"**进行测试,如果显示 SUCCESS 则表示添加成功。
配置 phpunit.xml
phpunit.xml 是 phpunit 这个工具用来单元测试所需要的配置文件。这个文件的名称同样也是可以自定义的,但是要在"build.xml"中配置好名字就行。默认情况下,用"phpunit.xml", 则不需要在"build.xml"中配置文件名。
build.xml 中 phpunit 配置
fileset dir 指定单元测试文件所在路径,include 指定包含哪些文件,支持通配符匹配。当然也可以用 exclude 关键字指定不包含的文件。
# jenkins 权限管理
由于 jenkins 默认的权限管理体系不支持用户组或角色的配置,因此需要安装第三发插件来支持角色的配置,本文将使用 Role Strategy Plugin。基于这个插件的权限管理设置请参考这篇文章:http://blog.csdn.net/russ44/article/details/52276222 (opens new window),这里不作详细介绍。
至此,就可以用 jenkins 周而复始的进行 CI 了,当然 jenkins 是一个强大的工具,功能绝不仅仅是以上这些,其他方面要是以后用到,我会更新到这篇文章中。有疑问欢迎在下方留言。
# Jenkins FAQ
# 登录密码
如果不知道初始登录密码,可以通过以下方式查看:
执行命令 cat /root/.jenkins/secrets/initialAdminPassword
,打印出来的即是初始登录密码。
# 忘记密码
1.执行 vim /root/.jenkins/config.xml
,删除以下内容
<useSecurity>true</useSecurity>
<authorizationStrategy class="hudson.security.FullControlOnceLoggedInAuthorizationStrategy">
<denyAnonymousReadAccess>true</denyAnonymousReadAccess>
</authorizationStrategy>
<securityRealm class="hudson.security.HudsonPrivateSecurityRealm">
<disableSignup>true</disableSignup>
<enableCaptcha>false</enableCaptcha>
</securityRealm>
2.重启 Jenkins 服务;
3.进入首页>“系统管理”>“Configure Global Security”;
4.勾选“启用安全”;
5.点选“Jenkins 专有用户数据库”,并点击“保存”;
6.重新点击首页>“系统管理”,发现此时出现“管理用户”;
7.点击进入展示“用户列表”;
8.点击右侧进入修改密码页面,修改后即可重新登录。
# 卡在 check 页面
现象:输入密码后,卡在 check 页面
原因:jenkins 在安装插件前总是尝试连接 www.google.com,来判断网络是否连通。谷歌的网站在大陆是连不上的,所以会出现这个问题。
解决方案:执行vim /root/.jenkins/updates/default.json
,将 connectionCheckUrl
后的 www.google.com
改为 www.baidu.com
。然后重启即可。
或者直接执行命令:
sed -i 's/www.google.com/www.baidu.com/g' /root/.jenkins/updates/default.json
# 卡在 getting startted 页面
现象:卡在 getting startted 页面
原因:jenkins 默认的插件下载服务器地址在国外,如果不翻墙下载不了。
解决方案:执行vim /root/.jenkins/hudson.model.UpdateCenter.xml
,将 <url>
改为 http://mirror.xmission.com/jenkins/updates/update-center.json
。然后重启即可。
或者直接执行命令:
sed -i '/^<url>/s/.*/<url>http:\/\/mirror.xmission.com\/jenkins\/updates\/update-center.json<\/url>/g' /root/.jenkins/hudson.model.UpdateCenter.xml
# 以 root 用户运行
(1)修改 jenkins 用户
vim /etc/sysconfig/jenkins
修改用户
$JENKINS_USER="root"
(2)修改 Jenkins
相关文件夹用户权限
chown -R root:root /var/lib/jenkins
chown -R root:root /var/cache/jenkins
chown -R root:root /var/log/jenkins
(3)重启 Jenkins
systemctl restart jenkins
# 参考资料
官方
引申
文章
- https://jenkins.io/doc/pipeline/tour/getting-started/
- https://www.cnblogs.com/austinspark-jessylu/p/6894944.html
- http://blog.csdn.net/jlminghui/article/details/54952148
- Jenkins 详细教程 (opens new window)