ansible+jenkins实战

1、部分机器信息:
ansible+jenkins+svn实现生产环境自动发布_第1张图片
2、远程执行用户:(ansible机器并没有开通外网哦)
ansible_ssh_port=22   ansible_ssh_user=ane    ansible_ssh_pass=ane
ansible+jenkins+svn实现生产环境自动发布_第2张图片
3、ansible用到的两个重要角色

/etc/ansible/hosts      #hosts文件定义主机与和执行权限
/etc/ansible/roles       #roles是任务集合,可在roles下面新建多模块,如tomcat,jdk、yum源,防火墙等,分角色方便管理且灵活

##Jenkins配置
1、新建-自由分格项目
项目名称:lbbs
Svn配置:(这个svn地址也是内网哦)
地址:svn://172.17.103.10:3391/lbproject/bs/
ansible+jenkins+svn实现生产环境自动发布_第3张图片
###构建:
1)、增加构建后的操作-->Invoke Ansible Playbook
ansible+jenkins+svn实现生产环境自动发布_第4张图片

Playbook path:/etc/ansible/roles/lbbs/lbbs.yml (备注:该路径为ansible的roles)
Inventory:选择File or host list File path or comma separated host list:/etc/ansible/hosts (备注:该路径为ansible的hosts文件)
Hostsubset:lbbs (备注:此处为hosts文件中ip或者定义的主机组都行

ansible+jenkins+svn实现生产环境自动发布_第5张图片

[root@lbzpf bs]# cat /etc/ansible/roles/lbbs/tasks/main.yml 
- name: copy package to 103.111 
  copy: 
    src={{ src_path }}/103.111/ne-ops-1.0.0.war
    dest={{ dest_path }}   
    backup=yes  #开启远程备份,在远程主机/ane/update下备份
  when: "ansible_nodename == 'lb_bs1' and ansible_eth0.ipv4.address == '172.17.103.111'"   #条件判断 
- name: copy package to 103.32 
  copy:
    src={{ src_path }}/103.32/ne-ops-1.0.0.war
    dest={{ dest_path }}
    backup=yes
  when: "ansible_nodename == 'bs-web04' and ansible_eth0.ipv4.address == '172.17.103.32'"
备注:加when条件判断原因是:war包里有个文件引用了当前的主机ip,没办法,只能这样了

[root@lbzpf bs]# cat  /etc/ansible/roles/lbbs/vars/main.yml   #vars定义了上面用到的两个变量路径
src_path: /var/lib/jenkins/workspace/lbbs    #源路径
dest_path: /ane/update   #目标路径

ansible+jenkins+svn实现生产环境自动发布_第6张图片
2)、增加构建后的操作-->(Invoke Ansible Ad-Hoc Command)
ansible+jenkins+svn实现生产环境自动发布_第7张图片
###发布
1、Jenkins中点击立即构建,或者指定定时任务,
ansible+jenkins+svn实现生产环境自动发布_第8张图片
2、编写计划任务发布
发布时间一般是固定的,所以可以指定定时任务(通linux下的crond),让其自动构建操作
ansible+jenkins+svn实现生产环境自动发布_第9张图片

检查执行结果
ansible+jenkins+svn实现生产环境自动发布_第10张图片
ansible+jenkins+svn实现生产环境自动发布_第11张图片
ansible+jenkins+svn实现生产环境自动发布_第12张图片