共计 3586 个字符,预计需要花费 9 分钟才能阅读完成。
一、概述
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/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
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
三、测试验证
安装 web
在 web 定义的主机组内的主机 172.20.4.51 上查看 httpd 与 php 配置
安装 db
在 db 定义的主机组内的主机上 172.20.4.52 查看 mysql 服务
下面关于 Ansible 的文章您也可能喜欢,不妨参考下:
使用 Ansible 批量管理远程服务器 http://www.linuxidc.com/Linux/2015-05/118080.htm
在 CentOS 7 中安装并使用自动化工具 Ansible http://www.linuxidc.com/Linux/2015-10/123801.htm
CentOS 7 上搭建 Jenkins+Ansible 服务 http://www.linuxidc.com/Linux/2016-12/138737.htm
Linux 下源码编译安装 Ansible 及排错记录 http://www.linuxidc.com/Linux/2017-03/141427.htm
Ansible 基础—安装与常用模块 http://www.linuxidc.com/Linux/2017-02/140216.htm
Ansible 配置及使用 http://www.linuxidc.com/Linux/2017-03/142121.htm
自动化运维工具 Ansible 使用教程 http://www.linuxidc.com/Linux/2017-12/149671.htm
自动化运维工具之 Ansible 介绍及安装使用 http://www.linuxidc.com/Linux/2016-12/138104.htm
自动化运维之 Ansible 详解 http://www.linuxidc.com/Linux/2017-03/142191.htm
Ansible 入门 notify 和 handlers http://www.linuxidc.com/Linux/2017-02/140871.htm
CentOS 6.5 安装自动化工具 Ansible 和图形化工具 Tower http://www.linuxidc.com/Linux/2017-03/141422.htm
Ansible 的详细介绍:请点这里
Ansible 的下载地址:请点这里
本文永久更新链接地址:http://www.linuxidc.com/Linux/2017-12/149674.htm