##主要过程##
1. zabbix 维护模式通过ansible的 zabbix_maintenance 模块来实现
2. jenkins 调用ansible执行playbook
##最终效果##
用户可多选应用组,设置维护时长,最终确认操作。
##具体实现##
1.一些安全选项,和丢弃策略:
2.设置参数Influence,用来提供多选项,最终用户可选择业务范围,此处插件名称是:Extended Choice Parameter
3.设置文本参数Periods,用来提供时长,文本参数的用意在于让用户可以自己填数值。
4.设置布尔型参数Confirm,用于让用户确认操作。
5.选择构建环境,这里配置了颜色方案xterm
6.设置构建过程。
本次构建的最终目的,是为了执行一条ansible-playbook 的命令,该命令将Influence ,Periods 作为其参数,最终执行。
命令是这样的: /usr/local/bin/ansible-playbook /data/ansible/playbooks/zabbix_maintenance.yml -f 5 --private-key /tmp/ssh1823040893798812862.key -u root -e period=60 --extra-vars @tmp.json
所以, 我们来看看上述命令中的参数都怎么来的:
a. -f 5
这个参数来自ansible插件的选项:
b. --private-key
这里面可选的key,都是在jenkins Credentials 中定义好的,我们在这里统一管理jenkins所有的key;至于,为何是/tmp/xxxx.key ,这是jenkins的安全机制;
c. -u root
ansible 的执行用户在这里设置,如果不设置,默认是用root执行。
d. -e period=60
这是我前面设置的文本参数Periods,在这里映射成为ansible的一个变量,ansible插件可以指定key:value,将前面的自定义变量映射过来。
最终,也就是使他能够接收用户构建时的所填的时间。
e. --extra-vars @tmp.json
这个参数的意思,是从json文件中导入值,作为ansible的变量参数。(因为我们有可能指定多个参数,这里方便统一格式。)
上面的变量映射,目前只支持 -e ,要想自定义一些选项,ansible 插件已经帮你想好了:
f. 以上,我们解决了ansible-playbook 整条命令的构成,但是,距离我们最终的目标还差2个东西:
“确认”操作怎么实现,tmp.json文件怎么组成? 而这两个操作必须要在ansible-playbook 执行之前就组织好。
这里,我们借助jenkins 的 shell工具:
脚本的意思很明了:接收Boolean 变量$Confirm的结果,如果是true,就开始接收Influence变量的结果,并组织成json格式,写入tmp.json
这样,构建过程就设置好了。
7.构建后操作。
因为我们每次构建的时候,tmp.json 都应该是新生成的,所以每次构建完,都要删除tmp.json。
###ansible-playbook###
下面是我们具体的playbook:
root@nj-jenkins-make-st:/data/ansible/playbooks# vi zabbix_maintenance.yml
• hosts:
localhost
tasks: • name: Create a named maintenance window for SCM
zabbix_maintenance:
name: routine_update
host_groups: "{{ zabbix_hosts_groups }}"
state: present
collect_data: false
minutes: "{{ period }}"
validate_certs: no
server_url: https://www.zabbix.example.comlogin_user: sa_zabbix
login_password: adsadas
###总结###
这个任务的构建思路是:
1.先编写ansible-playbook,在写的过程中,考虑哪些作为变量,从用户端去接收变量值。
2.在jenkins中,把ansible的变量映射出来,并组织好格式,添加一些自己想要的功能,最终形成一个完整的构建。
转载于:https://blog.51cto.com/570836653/2375548