要对 Jenkins 系统进行备份,本质上是对 Jenkins 的文件和目录进行备份,如果没有做特殊设置的话也就是 Jenkins 的安装目录 /var/jenkins_home,知道这个原理后就简单了,我们可以写个 Shell 脚本,在脚本中对 Jenkins 目录进行打包存档,然后添加一个系统定时任务,定期执行 Shell 脚本来存档 Jenkins 目录,需要进行恢复的时候就用存档的内容全部覆盖到 Jenkins 目录。还有一种方式就是利用 Jenkins 的备份插件,安装好 Jenkins 的备份插件后进行一些简单设置,备份插件就会定期对 Jenkins 系统进行备份,需要恢复的时候还是在插件的设置界面进行恢复操作。
第一种方式
采用 Shell 脚本备份 Jenkins 目录,利用 tar 命令归档打包文件,如果想要排除某些文件和目录可以追加 exclude 指令。
#!/usr/bin/env bash
# 指定Jenkins的安装目录路径
jenkins_home='jenkins_home_path'
current_date=$(date '+%Y%m%d')
cd $jenkins_home || exit
# 按日期备份
tar -cvzf ../jenkins_home_"$current_date".tar *
第二种方式
采用 Jenkins 插件备份 Jenkins 系统。在 Jenkins 的可选插件中搜索 backup 关键词,看到只有如下几个插件可选:
对比了这几个备份插件,目前就只有这两个还在维护,Periodic Backup 、ThinBackup,其他的最后一次发布都是好几年之前了,并且也只有 Periodic Backup
和 ThinBackup
插件的备份内容比较全面,其他的都只是备份 Jenkins 的配置文件。经过我的使用体验后发现 Periodic Backup
和 ThinBackup
插件的设置也是比较相似的。我这个就演示下 Periodic Backup
插件的使用。
安装 Periodic Backup
插件后在 Jenkins 的【系统管理】中会多出一个【Periodic Backup Manager】选项。
备份插件设置,主要是设置备份文件的存储位置和存储格式,以及备份频率和要忽略的文件及文件夹。因为备份时会占用 CPU,我们这里将【Backup schedule (cron) 】设置在每天午夜执行备份操作,这里的 schedule 设置支持标准的 cron 表达式。
关于 Jenkins trigger cron
类似UNIX cron语法,一段 cron 包含5个字段。使用空格或tab分隔
格式为:
分钟:0~59
小时:0~23
一月某一天:1~31
月份:1~12
星期几:0~7
还可以使用以下字符,一次性指定多个值
*:匹配所有值
M-N:匹配M到N之间的值
M-N/X:指定M到N范围内,以X值为步长
A,B,C:逗号分隔枚举多个值
有时候存在大量同一时刻执行的定时任务,比如N个半夜零点(0 0 * * *)执行的任务,这样会产生负载不均衡,Jenkins提供了H字符来解决这一问题,H表示hash,(0 0 * * *)表示零点0分至0点59分之间任何一个时间点
Jenkins trigger cron 提供了更便捷的写法 @yearly, @monthly,@weekly, @daily,@hourly
缩写 | 等价写法 | 描述 |
---|---|---|
@daily 或 @midnight | 0 0 * * * | 每天午夜0点执行 |
@hourly | 0 * * * * | 每个整点0分执行 |
@monthly | 0 0 1 * * | 每月1号的午夜执行 |
@weekly | 0 0 * * 0 | 每周日午夜执行 |
@yearly 或 @annually | 0 0 1 1 * | 每年1月1日的午夜执行 |
在【Excludes list】选项中设置要忽略的文件或者文件夹,用英文符号 ; 分割:
*.log;workspace;*.jar;*.zip;*.gz;node_modules;*.hprof;*.apk;*.ipa;*.aar
全部设置如下图:
设置好后可以点击【Backup Now!】立即备份一下,也可以等着每天午夜备份插件自动备份。备份后在【Periodic Backup Manager】插件页面可以看到已有的备份,如果需要恢复,选择一个时间节点的备份文件进行【Restore selected backup】恢复即可。
ThinBackup
配置说明
Backup directory:
备份目录,用于存储备份的文件,如果指定的目录不存在,默认在进行备份之前会自动创建。
Backup schedule for full backups:
进行备份的计划任务,与linux下的crontab一样,其中上面的H,代表哈希,为了允许定期调度的任务在系统上产生均匀负载,应尽可能使用符号H(用于“散列”)。例如,如果多个job都设置使用0 0 * * *
将导致负载大幅飙升。相比之下,使用H H * * *仍然会每天执行一次每个job,但不会同时执行,更好地使用有限的资源。
Backup schedule for differential backups:
进行差异化备份的计划任务,同上。
Max number of backup sets:
备份的最大数量。
Files excluded from backup (regular expression):
不需要进行备份的文件的正则表达式。
Wait until Jenkins/Hudson is idle to perform a backup:
等待jenkins空闲多长时间后进行备份。
Backup build results:
如果启用此选项,还将备份构建结果,一般不建议勾选此选项。
Backup 'userContent' folder:
备份${jenkins_home}/userContent
目录下的文件。
Backup next build number file:
备份jenkins构建的build id文件。
Backup plugins archives:
备份插件。
Clean up differential backups:
完成备份以后清除所有的差异备份。
Move old backups to ZIP files:
如果选中此选项,则无论何时执行新的完整备份,所有旧备份集都将移至ZIP文件。每个ZIP文件将包含一个备份集,即一个完整备份和任何引用该备份文件的差异备份。文件名将标识包含备份的时间范围(即完整备份的时间戳和最新差异备份的时间戳)。
备份策略根据自己实际情况定义即可。
保存后回到ThinBackup
界面,除了可以自动进行备份外,也可以通过手动备份,点击Backup Now
按钮就会立即进行备份。如下按钮:
备份完后会在上面设定的备份目录下生成一个以FULL-
开头,以当前时间(精确到分)为结尾的目录,该目录下就是默认所有的Jenkins配置。
当要使用备份文件进行恢复的时候,点击restore按钮,在跳转的界面中就会显示出该备份文件的备份时间,点击Restore即可。
网友评论