一、ansible roles
Ansible roles 是为了层次化,结构化的组织Playbook。roles就是通过分别将变量、文件、任务、模块及处理器放置于单独的目录中,并可以便捷地include它们。roles一般用于基于主机构建服务的场景中,在企业复杂业务场景中应用的频率很高,以特定的层级目录结构进行组织的tasks、variables、handlers、templates、files等;相当于函数的调用把各个功能切割成片段来执行。
二、roles目录说明
1. role存放的路径在配置文件ansible.cfg中定义
roles_path = ~/ansible/roles 默认目录:/etc/ansible/roles
2. 每个role目录下会有许多层级目录
层级目录名称 | 描述 |
files | 存放copy或script等模块调用的函数 |
tasks | 定义各种task,要有main.yml,其他文件include包含调用 |
handlers | 定义各种handlers,要有main.yml,其他文件include包含调用 |
vars | 定义variables,要有main.yml,其他文件include包含调用 |
templates | 存储由template模块调用的模板文本 |
meta | 定义当前角色的特殊设定及其依赖关系,要有main.yml的文件 |
tests | 用于测试角色 |
defaults | 要有main.yml的文件,用于设定默认变量 |
三、role的自定义设定与使用
1. 相关命令
ansible-galaxy init apache ##创建名为apache的role,需要先切换到设定的roles目录下
ansible-galaxy list ##查看所有role
2. playbook中使用roles
vim test.yml
---
- name: xxxx
hosts: xxxx
roles:
- role: apache
- role: xxxx
3. playbook中使用roles时控制任务执行顺序
vim test.yml
---
- name: xxxx
hosts: xxxx
roles:
- role: apache
- role: xxxx
pre_tasks: ##在执行role之前执行
- task1
post_tasks:
- task2 ##在执行role之后执行
...
四、role的安装
role除了可以自己编写,也可以安装已经写好的role
1. 安装 galaxy.ansible.com 上的role
Ansible Galaxy 是一个免费共享和下载 Ansible 角色的网站,可以帮助我们更好的定义和学习roles。ansible-galaxy命令默认与https://galaxy.ansible.com网站API通信,可以查找、下载各种社区开发的 Ansible 角色。
在浏览器中访问该网站,找到想要下载的role。直接在shell中执行 Installation 即可安装
2. 安装本地role
vim install_apache_role.yml ##编写安装play
---
- src: file:///home/lee/apache.tar.gz ##指定安装源文件
name: apache ##给role命名
ansible-galaxy install -r install_apache_role.yml