Ansible Roles是ansible自1.2版本开始引入的新特性,用于层次性、结构化地组织playbook。
Roles能够根据层次型结构自动加载template、变量文件、tasks以及handlers等。
1. Role路径
# /home/user/.ansible/roles # /usr/share/ansible/roles # /etc/ansible/roles
2. 下载系统Role
# yum install -y rhel-system-rols
# ansible-galaxy list
- linux-system-roles.kdump, (unknown version)
- linux-system-roles.network, (unknown version)
- linux-system-roles.postfix, (unknown version)
- linux-system-roles.selinux, (unknown version)
- linux-system-roles.timesync, (unknown version)
- rhel-system-roles.kdump, (unknown version)
- rhel-system-roles.network, (unknown version)
- rhel-system-roles.postfix, (unknown version)
- rhel-system-roles.selinux, (unknown version)
- rhel-system-roles.timesync, (unknown version)
3. 从指定地点下载Role
# cat install_role.yaml
- src: https://github.com/bennojoy/nginx
path: vagrant/roles/
# from github, overriding the name and specifying a specific tag
- src: https://github.com/bennojoy/nginx
version: master
name: nginx_role
# ansible-galaxy install -r install_role.yaml
4. 创建Role
使用方法可以参考系统Role的示例,路径:/usr/share/doc/rhel-system-roles/
# cd /etc/ansible/roles
# ansible-galaxy init test-role
# tree test-role
.
├── defaults # 此目录应当包含一个main.yml文件,用于为当前角色设定默认变量。
│ └── main.yml
├── files # 用来存放由copy模块或script模块调用的文件。
├── handlers # 此目录应当包含一个main.yml文件,被task中的notify调用。
│ └── main.yml
├── meta # 存放Role相关信息,如作者,许可证,平台等信息。
│ └── main.yml
├── README.md
├── tasks # 此目录应当包含一个main.yml文件,用于定义此角色的任务列表。
│ └── main.yml
├── templates # 用来存放jinjia2模板,template模块会自动在此目录中寻找jinjia2模板文件,而不需要写路径。
├── tests # 用于Role测试。
│ ├── inventory
│ └── test.yml
└── vars # 此目录应当包含一个main.yml文件,用于定义此角色用到的变量。
└── main.yml
5. 调用Role
---
- name:
hosts: dev
vars:
xxx: xxx
roles:
- test-role
Ansible Roles详解
1598

被折叠的 条评论
为什么被折叠?



