ansible入门六(roles)
一、什么场景下会用roles?
假如我们现在有3个被管理主机,第一个要配置成httpd,第二个要配置成php服务器,第三个要配置成MySQL服务器。我们如何来定义playbook?
第一个play用到第一个主机上,用来构建httpd,第二个play用到第二个主机上,用来构建php,第三个play用到第三个主机上,用来构建MySQL。这些个play定义在playbook中比较麻烦,将来也不利于模块化调用,不利于多次调。比如说后来又加进来一个主机,这个第4个主机既是httpd服务器,又是php服务器,我们只能写第4个play,上面写上安装httpd和php。这样playbook中的代码就重复了。
为了避免代码重复,roles能够实现代码重复被调用。定义一个角色叫websrvs,第二个角色叫phpappsrvs,第三个角色叫dbsrvs。那么调用时如下来调用:
- hosts: host1
- role:
- - websrvs
- hosts: host2
- role:
- - phpappsrvs
- hosts: host3
- role:
- - dbsrvs
- hosts: host4
- role:
- - websrvs
- - phpappsrvs
这样代码就可以重复利用了,每个角色可以被独立重复调用。下面举例说明使用方式。
二、roles示例
假设有3台主机,172.16.7.151主机上安装MySQL,172.16.7.152上安装httpd,172.16.7.153上安装MySQL和httpd。我们建立两个角色websrvs和dbsrvs,然后应用到这几个主机上。
1. 创建roles的必需目录
- [root@node1 opt]# mkdir -pv ansible_playbooks/roles/{websrvs,dbsrvs}/{tasks,files,templates,meta,handlers,vars}
每个role下面有个目录叫meta,在里面可以新建文件main.yml,在文件中可以设置该role和其它role之前的关联关系。
2. 配置角色
(1)配置角色websrvs
- [root@node1 opt]# cd ansible_playbooks/roles/
- [root@node1 roles]# cd websrvs/
- [root@node1 websrvs]# ls
- files handlers meta tasks templates vars
a. 将httpd配置文件上传到files目录下,我这里假设httpd.conf每台主机都是一样的,实际上应该用模板,先用一样的配置文件举例
- [root@node1 websrvs]# cp /etc/httpd/conf/httpd.conf files/
直接复制的静态文件都放在files目录下。打算用模板文件的都放在templates目录下。
b.编写任务列表tasks
- [root@node1 websrvs]# vim tasks/main.yml
- - name: install httpd package
- yum: name=httpd
- - name: install configuration file
- copy: src=httpd.conf dest=/etc/httpd/conf
- tags:
- - conf
- notify:
- - restart httpd
- - name: start httpd
- service: name=httpd state=started
c.由于上面的tasks中定义了notify,所以要定义handlers
- [root@node1 websrvs]# vim handlers/main.yml
- - name: restart httpd
- service: name=httpd state=restarted
如果需要定义变量,则在vars目录下创建main.yml文件,在文件中写入变量,以key:value的形式定义,比如:
- http_port: 8080
(2)配置角色dbsrvs
- [root@node1 roles]# cd dbsrvs/
- [root@node1 dbsrvs]# ls
- files handlers meta tasks templates vars
a.将MySQL配置文件上传到files目录下。
b.编写任务列表tasks
- [root@node1 dbsrvs]# vim tasks/main.yml
- - name: install mysql-server package
- yum: name=mysql-server state=latest
- - name: install configuration file
- copy: src=my.cnf dest/etc/my.cnf
- tags:
- - conf
- notify:
- - restart mysqld
- - name:
- service: name=mysqld enabled=true state=started
c.定义handlers
- [root@node1 dbsrvs]# vim handlers/main.yml
- - name: restart mysqld
- service: name=mysqld state=restarted
(3)定义playbook
【注意】:要在roles目录同级创建playbook。
- [root@node1 ansible_playbooks]# vim web.yml
- - hosts: 172.16.7.152
- roles:
- - websrvs
- [root@node1 ansible_playbooks]# vim db.yml
- - hosts: 172.16.7.151
- roles:
- - dbsrvs
- [root@node1 ansible_playbooks]# vim site.yml
- - hosts: 172.16.7.153
- roles:
- - websrvs
- - dbsrvs
运行:
- [root@node1 ansible_playbooks]# ansible-playbook web.yml
- [root@node1 ansible_playbooks]# ansible-playbook db.yml
- [root@node1 ansible_playbooks]# ansible-playbook site.yml
当然也可以把这些内容写入同一个playbook中。playbook的名字可以自定义。