一、概述

1.1 概念

roles 用于层次性、结构化地组织playbook。roles 能够根据层次型结构自动装载变量文件、tasks以及handlers等。要使用roles只需要在playbook中使用include指令即可。简单来讲,roles就是通过分别将变量(vars)、文件(file)、任务(tasks)、模块(modules)及处理器(handlers)放置于单独的目录中,并可以便捷地include它们的一种机制。角色一般用于基于主机构建服务的场景中,但也可以是用于构建守护进程等场景中。

1.2 roles目录结构

[root@puppet-server web]# tree  /etc/ansible//etc/ansible/├── ansible.cfg├── hosts└── roles    ├── db                        #定义db角色    │   ├── files    │   │   └── my.cnf    │   ├── handlers    │   │   └── main.yml    │   └── tasks    │       └── main.yml    ├── db.yml    ├── php                        #定义php角色    │   ├── files    │   │   └── php.ini    │   └── tasks    │       └── main.yml    ├── web                        #定义web角色    │   ├── default               #设定默认变量时使用此目录中的main.yml文件。    │   ├── files                 #存放文件,对应于tasks中copy模块或scripts模块中的文件    │   │   └── httpd.conf    │   ├── handlers              #定义触发器;至少应该包含一个名为main.yml的文件;其他的文件需要在此文件中通过include进行包含。    │   │   └── main.yml    │   ├── meta                  #定义变量;至少应该包含一个名为main.yml的文件;定义当前角色的特殊设定及其依赖关系;其他的文件需要在此文件中通过include进行包含。    │   ├── tasks                 #定义任务;至少应该包含一个名为main.yml的文件;其他的文件需要在此文件中通过include进行包含。    │   │   └── main.yml    │   ├── templates             #template模块查找所需要模板文件目录;    │   └── vars                  #定义变量;至少应该包含一个名为main.yml的文件;其他的文件需要在此文件中通过include进行包含。    └── web.yml注:没有存放文件的目录可以不创建

二、安装web与db环境

主机名 IP地址 作用
ansible-server 172.20.4.50 ansible控制端
ansible-1 172.20.4.51 安装web环境
ansible-2 172.20.4.52 安装db环境

2.1 配置httpd角色

cd /etc/ansible/roles/webcat tasks/main.yml - name: install httpd  yum: name=httpd state=present- name: configuration httpd  copy: src=httpd.conf dest=/etc/httpd/conf/httpd.conf  notify:  - restart httpd- name: start httpd  service: name=httpd state=started enabled=yes
cat handlers/main.yml - name: restart httpd  service: name=httpd state=restarted

将已经编辑好的httpd.conf配置文件存放到files目录下

cat /etc/ansible/roles/php/tasks/main.yml - name: install php  yum: name=php state=present- name: configuration php  copy: src=php.ini dest=/etc/php.ini

2.2 配置php角色

将已经配置好的php.ini 存放到php目录下的files目录内

cat /etc/ansible/roles/web.yml - name: web  remote_user: root  hosts: agent  roles:  - php  - web

查看整体web.yml

cat /etc/ansible/roles/web.yml - name: web                              remote_user: root  hosts: web                  roles:  - php  - web

2.3 配置db角色

cat /etc/ansible/roles/db/tasks/main.yml - name: install mysql service  yum: name=mysql-server state=present- name: configuration mysql  copy: src=my.cnf dest=/etc/my.cnf  notify:  - restart mysqld- name: start mysqld  service: name=mysqld state=started enabled=yes
cat /etc/ansible/roles/db/handlers/main.yml - name: restart mysqld  service: name=mysqld state=restarted

将已经配置好的php.ini 存放到php目录下的files目录内

查看整体db.yml

cat /etc/ansible/roles/db.yml - name: mysqld service  remote_user: root  hosts: db  roles:  - db

三、测试验证

dc3eeb4fbf809d852a5a2fb83e054584.png

安装web

在web定义的主机组内的主机172.20.4.51上查看httpd与php配置

b4c2a6f20592d209f51464fcb37b34d8.png

安装db

在db定义的主机组内的主机上172.20.4.52查看mysql服务