一、理解roles在企业中的定位及写法
#ansible 角色简介#
- Ansible roles 是为了层次化,结构化的组织Playbook
- roles就是通过分别将变量、文件、任务、模块及处理器放置于单独的目录中,并可以便捷地include它们
- roles一般用于基于主机构建服务的场景中,在企业复杂业务场景中应用的频率很高
- 以特定的层级目录结构进行组织的tasks、variables、handlers、templates、files等;相当于函数的调用把各个功能切割
成片段来执行
#roles目录结构#
files | 存放copy或script等模块调用的函数 |
---|---|
tasks | 定义各种task,要有main.yml,其他文件include包含调用 |
handlers | 定义各种handlers,要有main.yml,其他文件include包含调用 |
vars | 定义variables,要有main.yml,其他文件include包含调用 |
templates | 存储由template模块调用的模板文本 |
meta | 定义当前角色的特殊设定及其依赖关系,要有main.yml的文件 , defaults##要有main.yml的文件,用于设定默认变量 |
tests | 用于测试角色 |
建立项目及目录
写入执行的动作
vim vsftpd/tasks/main.yml
生成模板
匿名用户可以去登陆
指定变量
vim vsftpd/handlers/main.yml
写入触发器
二、关于roles执行的技巧
控制任务执行顺序
– hosts: server2
roles:
– role: role1 ##角色任务
pre_tasks: ##角色执行前执行的play
– tasks1
tasks: ##普通任务
– tasks2
post_tasks: ##在角色和普通任务执行完毕后执行的play
– tasks3
handlers:
三、role的下载和共享
#ansible—galaxy命令工具#
- Ansible Galaxy 是一个免费共享和下载 Ansible 角色的网站,可以帮助我们更好的定义和学习roles。
- ansible-galaxy命令默认与https://galaxy.ansible.com网站API通信,可以查找、下载各种社区开发的 Ansible 角色
- ansible-galaxy在 Ansible 1.4.2 就已经被包含了
- 在galaxy.ansible.com网站查询roles
登陆网站 查找需要的内容