data:image/s3,"s3://crabby-images/d788b/d788baf76b3f9625c7f7330d7d159f2a3d636a22" alt="bVbm4ca?w=815&h=218"
流水线视图可以很直观地看到每一步执行的时间和进度,方便追踪部署过程中的每一个环节。
搭建 jenkins 参考 上一篇文章
工作流
本文目的是搭建一个简单的 pipeline,当 git 仓库有提交时,builder server 进行构建和测试,完成之后 deploy server 进行部署。
本地 -> SCM: 提交代码
SCM -> Build Server: 触发 jenkins 任务
Build Server: 启动 pipeline
Build Server -> Deploy Server: 部署服务
SCM Source Code Management,如 github
Build Server jenkins 所在机器,负责构建
Deploy Server 线上服务所在机器
新建 Task
首先创建一个 Task,然后选择流水线模板
data:image/s3,"s3://crabby-images/ad70d/ad70d3f5b3b97f623b33c175891ed00373cec72c" alt="bVbm4l1?w=256&h=145"
data:image/s3,"s3://crabby-images/1fdec/1fdec1c29688d07c7d5030538a2a253b197df6e4" alt="bVbm4l5?w=1919&h=920"
配置
Pipeline
data:image/s3,"s3://crabby-images/e0a8f/e0a8fdc8a49f64627e9e396311cdd3504599f95e" alt="bVbm4uN?w=1440&h=431"
在这里可以配置 pipeline 的脚本,definition 可以选择 Pipeline script 或 Pipeline script from SCM。
选择前者后,jenkins 脚本需要在下方填写,当任务启动后,jenkins 会执行这里配好的命令;选择后者后,任务启动后,jenkins 会去执行 SCM 仓库下配置的 script path 下的脚本。
一句话说,两者区别在于脚本是写在 jenkins 配置里,还是写在你的代码仓库里。所以修改脚本的时候在 jenkins 里配就行,方便调试,没问题之后使用 SCM 管理更好。
编写 pipeline script
以 node 服务举例,部署过程分为四步:
Build: 在 build server 上 npm install
Test: 在 build server 上进行测试
Deploy: 在 deploy server 上部署
这个脚本如下,需要将 [user] 和 [ip] 替换成 deploy server 的登录用户和 ip:
pipeline {
agent any
stages {
stage('Build') {
steps {
sh "npm install"
}
}
stage('Test') {
steps {
sh "npm test"
}
}
stage('Deploy') {
steps {
sh """
ssh -o stricthostkeychecking=no [user]@[ip] "
source /etc/profile
cd /root/projects/my-api-server
git pull
npm install
pm2 reload wool-digger-api
"
"""
}
}
}
}
当然这是一个很粗糙的构建方式,可以稍后查看 使用 docker 进行改造。
主要概念有
agent 指示 Jenkins 分配一个执行器和工作空间来执行下面的Pipeline
stage 表示这个 Pipeline 的一个执行阶段,对应流水线中各个环节
steps 表示在这个 stage 中每一个步骤
sh 命令用来执行一条 shell 语句。 这个配置文件被执行后:
首先 jenkins 会在工作区(一般来说在 ~/.jenkins/workspace/)下拉取配置仓库指定分支的代码
pull 成功后进行 npm install(Build)
build 成功之后进行 npm test(Test)
test 成功后远程执行一段脚本,即登录 deploy server 并 cd 到服务目录,然后进行服务的更新重启操作。
npm/pm2 not found 的问题
注意上面 Deploy 中有一行 source /etc/profile,这是 login shell 和 no-login shell 的不同。
如果使用 ssh 登录再执行命令和脚本,用户会获得 login shell,shell 首先会加载 /etc/profile 文件,然后依次尝试 ~/.bash_profile、~/.bash_login 和 ~/.profile。
而如果直接使用 ssh 远程执行命令和脚本,如上面的 ssh -o,它不会去执行 /etc/profile 文件,而会去用户的 HOME 目录检查 .bashrc 并加载。所以在 /etc/profile 中设置的 path 不会生效。如果 nvm 在此文件中,那么 node、npm、pm2 等等就找不到了。
解决方法可以在 shell 脚本中先手动加载配置文件。
Build Triggers
data:image/s3,"s3://crabby-images/daf3e/daf3eefc3323e5fa5ef6ef3aba061cde985a9231" alt="bVbm4pg?w=1472&h=363"
在这里可以配置 pipeline 触发的类型
Github hook trigger fro GITScm polling
启动该项后可以通过 GitHub 的 webhook 来触发,参考 Github Plugin 文档
这里说一下最简单的配置,即手动配置。
在 Jenkins -> 系统管理 -> 系统设置中,可以找到 Git 配置,点击右边的问号按钮,可以看到默认的 jenkins hook 地址。
data:image/s3,"s3://crabby-images/9666a/9666a53149ac94e8034fe286b288fc0714912bb2" alt="bVbm5VD?w=404&h=423"
data:image/s3,"s3://crabby-images/4806c/4806ce67900669801c064b2aba4707ec026e8491" alt="bVbm5Wx?w=1556&h=230"
一般来说默认都是 $JENKINS_BASE_URL/github-webhook/。拿到这个地址后,添加到 github 的 webhook 中。
data:image/s3,"s3://crabby-images/a4371/a43714adf786e972fb8fb70caf1d3d31d73f71c7" alt="bVbm5WL?w=1043&h=357"
注意 这个地址是没有项目信息的,因为 github 调用这个 hook 地址时,会把仓库信息传过去,所以就只剩在 jenkins 中把 pipeline 和这个 git 仓库关联起来。这需要在 pipeline 中选择 Pipeline script from SCM 并填写 git 地址。
轮询 SCM
启动该项后,jenkins 将定时对 SCM 仓库进行轮询,当仓库有新提交时,会自动触发 pipeline。
Schedule 填写规则与 crond 类似,如 H/5 * * * * 代表每 5 分钟查询一次。详细规则可以点击右边的问号。
启动
点击 立即构建,或去仓库提交一个 commit(如果配置了 github hook),或提交一个 commit 并等待(如果配置了轮询 SCM),然后就能看到我们的第一个 pipeline 启动了!