roles可以根据层次型结构自动装载变量文件、task以及handlers等。简单来说,roles就是经过分别将变量、文件、任务、模块及处理器放置于单独的目录中,并能够便捷地include它们,roles通常用于基于主机构建服务的场景中,但也能够用于构建守护进程等场景中。php
[root@rabbitmq01 roles]# mkdir /etc/ansible/roles/httpd/{files,templates,tasks,handlers,valts,meta} -p #建立httpd服务所须要的目录 [root@rabbitmq01 roles]# ls httpd [root@rabbitmq01 roles]# cd httpd/ [root@rabbitmq01 httpd]# ls defaults files handlers meta tasks templates vars
[root@rabbitmq01 httpd]# mkdir /etc/ansible/roles/mysql/{files,templates,tasks,handlers,vars,defaults,meta} -p
#建立mysql服务所须要的目录mysql
[root@rabbitmq01 httpd]# mkdir /etc/ansible/roles/php/{files,templates,tasks,handlers,vars,defaults,meta} -p
#建立php服务所须要的目录web
#### 建立main.yml文件
[root@rabbitmq01 httpd]# touch /etc/ansible/roles/httpd/{defaults,vars,tasks,meta,handlers}/main.yml
[root@rabbitmq01 httpd]# touch /etc/ansible/roles/mysql/{defaults,vars,tasks,meta,handlers}/main.yml
[root@rabbitmq01 httpd]# touch /etc/ansible/roles/php/{defaults,vars,tasks,meta,handlers}/main.ymlsql
#### 编写httpd服务模块
[root@rabbitmq01 httpd]# vim tasks/main.yml apache
[root@rabbitmq01 httpd]# vim /etc/ansible/roles/httpd/vars/main.yml
[root@rabbitmq01 httpd]# cat /etc/ansible/roles/httpd/vars/main.yml
pkg: httpd
#定义变量:能够定义在全局变量中,也能够定义在roles角色变量中,通常定义在角色变量中vim
#### 编写mysql服务模块
[root@rabbitmq01 httpd]# vim /etc/ansible/roles/mysql/tasks/main.yml
[root@rabbitmq01 httpd]# cat /etc/ansible/roles/mysql/tasks/main.yml centos
[root@rabbitmq01 httpd]# vim /etc/ansible/roles/mysql/vars/main.yml
[root@rabbitmq01 httpd]# cat /etc/ansible/roles/mysql/vars/main.yml
pkg: mariadb*架构
#### 编写php服务模块
[root@rabbitmq01 httpd]# vim /etc/ansible/roles/php/tasks/main.yml
[root@rabbitmq01 httpd]# cat /etc/ansible/roles/php/tasks/main.ymlssh
[root@rabbitmq01 httpd]# vim /etc/ansible/roles/php/vars/main.yml
[root@rabbitmq01 httpd]# cat /etc/ansible/roles/php/vars/main.yml
pkg: phpide
#### 编写role文件
[root@rabbitmq01 httpd]# vim /etc/ansible/site.yml
[root@rabbitmq01 httpd]# cat /etc/ansible/site.yml
#### 运行文件
[root@rabbitmq01 ansible]# ansible-playbook site.yml --syntax-check
playbook: site.yml
[root@rabbitmq01 ansible]# ansible-playbook site.yml
PLAY [webserver] ****
TASK [Gathering Facts] **
Enter passphrase for key '/root/.ssh/id_rsa':
ok: [192.168.58.132]
TASK [httpd : ensure apache is at the latest version] ***
ok: [192.168.58.132]
TASK [mysql : ensure mysql is at the latest version] ****
ok: [192.168.58.132]
TASK [php : ensure php is at the latest version] ****
changed: [192.168.58.132]
PLAY RECAP **
192.168.58.132 : ok=4 changed=1 unreachable=0 failed=0
[root@rabbitmq02 ~]# rpm -q httpdhttpd-2.4.6-80.el7.centos.1.x86_64[root@rabbitmq02 ~]# rpm -q mariadbmariadb-5.5.56-2.el7.x86_64[root@rabbitmq02 ~]# rpm -q phpphp-5.4.16-45.el7.x86_64#能够看到安装成功