本文共 2865 字,大约阅读时间需要 9 分钟。
一、概述
1.1 概念
roles 用于层次性、结构化地组织playbook。roles 能够根据层次型结构自动装载变量文件、tasks以及handlers等。要使用roles只需要在playbook中使用include指令即可。简单来讲,roles就是通过分别将变量(vars)、文件(file)、任务(tasks)、模块(modules)及处理器(handlers)放置于单独的目录中,并可以便捷地include它们的一种机制。角色一般用于基于主机构建服务的场景中,但也可以是用于构建守护进程等场景中。
1.2 roles目录结构
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 | [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角色
1 2 3 4 5 6 7 8 9 10 | cd /etc/ansible/roles/web cat 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 |
1 2 3 | cat handlers /main .yml - name: restart httpd service: name=httpd state=restarted |
将已经编辑好的httpd.conf配置文件存放到files目录下
1 2 3 4 5 | 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目录内
1 2 3 4 5 6 7 | cat /etc/ansible/roles/web .yml - name: web remote_user: root hosts: agent roles: - php - web |
查看整体web.yml
1 2 3 4 5 6 7 | cat /etc/ansible/roles/web .yml - name: web remote_user: root hosts: web roles: - php - web |
2.3 配置db角色
1 2 3 4 5 6 7 8 9 | 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 |
1 2 3 | cat /etc/ansible/roles/db/handlers/main .yml - name: restart mysqld service: name=mysqld state=restarted |
将已经配置好的php.ini 存放到php目录下的files目录内
查看整体db.yml
1 2 3 4 5 6 | cat /etc/ansible/roles/db .yml - name: mysqld service remote_user: root hosts: db roles: - db |
三、测试验证
安装web
在web定义的主机组内的主机172.20.4.51上查看httpd与php配置
安装db
在db定义的主机组内的主机上172.20.4.52查看mysql服务