Ansible :roles
Roles:
用于层次性、结构化地组织playbook。roles 能够根据层次型结构自动装载变量文件、tasks以及handlers等。要使用roles只需 要在playbook中使用include指令即可。简单来讲,roles就是通过分别将变量、 文件、任务、模板及处理器放置于单独的目录中,并可以便捷地include它们的一 种机制。角色一般用于基于主机构建服务的场景中,但也可以是用于构建守护进程 等场景中
复杂场景:建议使用roles,代码复用度高
变更指定主机或主机组
变更指定主机或主机组
某些功能需多个Playbook,通过Includes即可实现
Ansible Roles目录编排
roles目录结构
每个角色,以特定的层级目录结构进行组织
roles目录结构:
Roles各目录作用:
/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
- (1) 创建以roles命名的目录
- (2) 在roles目录中分别创建以各角色名称命名的目录,如webservers等
- (3) 在每个角色命名的目录中分别创建files、handlers、meta、tasks、
- templates和vars目录;用不到的目录可以创建为空目录,也可以不创建
- (4) 在playbook文件中,调用各角色
针对大型项目使用Roles进行编排
roles目录结构:
playbook.yml roles/ project/ tasks/ files/ vars/ templates/ handlers/ default/ # 不经常用 meta/ # 不经常用
示例:
nginx-role.yml roles/ └── nginx ├── files │ └── main.yml ├── tasks │ ├── groupadd.yml │ ├── install.yml │ ├── main.yml │ ├── restart.yml │ └── useradd.yml └── vars └── main.yml
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 } #键role用于指定角色名称 #后续的k/v用于传递变量给角色
调用角色方法3:
roles:
- { role: nginx, username: nginx,when:ansible_distribution_major_version == ‘7’ }
roles playbook tags使用
--- - hosts: testweb remote_user: root roles: - { role: nginx ,tags: [ 'nginx', 'web' ] ,when: ansible_distribution_major_version == "6“ } - { role: httpd ,tags: [ 'httpd', 'web' ] } - { role: mysql ,tags: [ 'mysql', 'db' ] } - { role: marridb ,tags: [ 'mysql', 'db' ] } - { role: php } #挑标签执行
人生苦短,我用Python