A-Playbook-roles

时间:2023-02-23 12:59:39

roles

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

复杂场景:建议使用roles,代码复用度高 变更指定主机或主机组 如命名不规范维护和传承成本大 某些功能需多个Playbook,通过includes即可实现


角色(roles):角色集合

roles/
mysql/
httpd/
nginx/
memcached/

roles目录结构:

playbook.yml
roles/
project/
tasks/
files/
vars/
templates/
handlers/
default/ 不常用
meta/ 不常用

/roles/project/ :项目名称,有以下子目录

 files/ :存放由copy或script模块等调用的文件
 templates/: template模块查找所需要模板文件的目录
 tasks/:定义task,role的基本元素,至少应该包含一个名为main.yml的文件;其它的文件需要在此文件中通过include进行包含
 handlers/:至少应该包含一个名为main.yml的文件;其它的文件需要在此文件中通过include进行包含
 vars/:定义变量,至少应该包含一个名为main.yml的文件;其它的文件需要在此文件中通过include进行包含
 meta/:定义当前角色的特殊设定及其依赖关系,至少应该包含一个名为main.yml的文件,其它文件需在此文件中通过include进行包含
 default/:设定默认变量时使用此目录中的main.yml文件

创建role

创建role的步骤
(1) 创建以roles命名的目录
(2) 在roles目录中分别创建以各角色名称命名的目录,如webservers等
(3) 在每个角色命名的目录中分别创建files、 handlers、 meta、 tasks、
templates和vars目录;用不到的目录可以创建为空目录,也可以不创建
(4) 在playbook文件中,调用各角色

roles的示例如下所示:

site.yml
webservers.yml
dbservers.yml
roles/
common/
files/
templates/
tasks/
handlers/
vars/
meta/
webservers/
files/
templates/
tasks/
handlers/
vars/
meta/

playbook调用角色方法1

- hosts: websrvs
remote_user: root
roles:
- mysql
- memcached
- nginx

调用角色方法2

- hosts:
remote_user:
roles:
- mysql
- { role: nginx, username: nginx }

调用角色方法3:还可基于条件测试实现角色调用

roles:
- { role: nginx, username: nginx, when: ansible_distribution_major_version == ‘7’ }

Roles创建示例

mkdir -pv /etc/ansible/roles/nginx/{tasks,files,vars}
cd /etc/ansible/
vim roles/nginx/tasks/groupadd.yml

---
- name: add group nginx
user: name=nginx state=present

vim roles/nginx/tasks/filecp.yml
---
- name: file copy
copy: src=tom.conf dest=/tmp/tom.conf

相关文章