erweq 发表于 2017-10-20 10:44:38

自动化运维工具Ansible之roles

一、概述
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
# 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-server172.20.4.50ansible控制端
ansible-1172.20.4.51安装web环境
ansible-2172.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服务


看雪 发表于 2017-10-23 09:24:42

路过帮顶!!!
页: [1]
查看完整版本: 自动化运维工具Ansible之roles