一、Roles是什么?
编写playbook有个弊端就是无法实现复用
假设在同时部署Web、db、ha 时或不同服务器组合不同的应用就需要写多个yml文件。很难实现灵活的调用。。
roles 用于层次性、结构化地组织playbook。roles能够根据层次型结构自动装载变量文件、tasks以及handlers等。
要使用roles只需要在playbook中使用include指令即可。
简单来讲,roles就是通过分别将变量(vars)、文件(file)、任务(tasks)、模块(modules)及处理器(handlers)放置于单独的目录中,并可以便捷地include它们的一种机制。
角色一般用于基于主机构建服务的场景中,但也可以是用于构建守护进程等场景中。
二、目录层级说明
roles每个角色中,以特定的层级目录进行组织
Mysql/ 角色
Files/ #存放有copy或script模块等调用的文件;’
Tepmlates/ #template模块查找所需要模板文件目录;
Tasks/
#定义任务;至少应该包含一个名为main.yml的文件;其他的文件需要在此文件中通过include进行包含。
Handlers/
#定义触发器;至少应该包含一个名为main.yml的文件;其他的文件需要在此文件中通过include进行包含。
Vars/
#定义变量;至少应该包含一个名为main.yml的文件;其他的文件需要在此文件中通过include进行包含。
Meta/ #定义变量;至少应该包含一个名为main.yml的文件;定义当前角色的特殊设定及其依赖
关系;其他的文件需要在此文件中通过include进行包含。
Default/ #设定默认变量时使用此目录中的main.yml文件。
三、调用Roles实例
#创建固定目录结构 [root@ansible roles]# tree . ├── httpd │ ├── files │ │ └── httpd.conf │ └── tasks │ ├── copyfile.yml │ ├── main.yml │ └── user.yml ├── memcache ├── mysql └── nginx ├── main.yml ├── tasks │ ├── group.yml │ ├── restart.yml │ ├── start.yml │ ├── user.yml │ └── yum.yml └── templates 8 directories, 10 files [root@ansible roles]# cd nginx/ #定义执行的顺序 [root@ansible nginx]# cat main.yml - include: group.yml - include: user.yml - include: yum.yml - include: start.yml #每个任务分别写出来 [root@ansible nginx]# cd tasks/ [root@ansible tasks]# cat group.yml - name: create group group: name=nginx gid=80 [root@ansible tasks]# cat restart.yml - name: start service service: name=nginx state=restarted [root@ansible tasks]# cat start.yml - name: start service service: name=nginx state=started enabled=yes [root@ansible tasks]# cat user.yml - name: create user user: name=nginx group=nginx uid=80 system=yes shell=/sbin/nologin [root@ansible tasks]# cat yum.yml - name: yum install package yum: name=nginx 编写yml调用nginx角色 [root@ansible ansible]# cat role_nginx.yml - hosts: wsr remote_user: root roles: - role: nginx 通过ansible-playbook来执行 [root@ansible ansible]# ansible-playbook role_nginx.yml PLAY [wsr] ***************************************************************************** TASK [Gathering Facts] ***************************************************************** ok: [192.168.100.10] ok: [192.168.100.20] PLAY RECAP ***************************************************************************** 192.168.100.10 : ok=1 changed=0 unreachable=0 failed=0 skipped=0 rescued=0 ignored=0 192.168.100.20 : ok=1 changed=0 unreachable=0 failed=0 skipped=0 rescued=0 ignored=0