Ansible中的角色使用
Ansible Roles
Ansible 角色简介
Ansible Roles
是为了层次化,结构化的组织PlayBook.
roles就是通过分别将变量、文件、任务、模块及处理器放置于单独的目录中,并可以便捷的include
它们.
Roles
一般用于基于主机构建服务的场景中,在企业复杂业务场景中应用的频率很高.
(上文中的简单PlayBook用这种方式反而会显得麻烦.)
以特定的层级目录结构进行组织的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 ##用于测试角色
Roles存放的路径
在配置文件ansible.cfg中定义
roles_path = path/roles
默认目录:/etc/ansible/roles
创建目录结构
创建操作会在当前目录创建结构化的目录,因此需要先进入Roles目录下.
ansible-galaxy init Apache ##创建Apache项目的目录结构
ansible-galaxy list ##查看目录列表
在PlayBook中使用Roles
vim /root/.ansible/Roles/Apache/vars/main.yml
---
# vars file for Apache
PORT: 8080
vim /root/.ansible/Roles/Apache/tasks/main.yml
---
# tasks file for Apache
- name: Install Apache
dnf:
name: httpd
state: latest
- name: Config Apache
lineinfile:
path: /etc/httpd/conf/httpd.conf
regexp: "^Listen"
line: "Listen {{PORT}}"
notify: Restart Apache
changed_when: true
- name: Start Apache
service:
name: httpd
state: started
vim /root/.ansible/Roles/Apache/handlers/main.yml
---
# handlers file for Apache
- name: Restart Apache
service:
name: httpd
state: restarted
##组合组件并控制执行顺序
vim /root/.ansible/Test.yml
---
- name: 测试用例
- hosts: Test
roles:
- Apache
##存在普通任务和其他操作的执行顺序
vim /root/.ansible/Test.yml
---
- name: 测试用例
- hosts: Test
roles: ##角色任务
- Apache
pre_tasks: ##角色执行前执行的Play
- Task1
tasks: ##普通任务
- Task2
post_tasks: ##在角色和普通任务执行完毕后执行的Play
- Task3
handlers: ##触发器部分
通过Ansible Galaxy下载Roles
Ansible Galaxy
是一个免费共享和下载 Ansible
角色的网站,可以帮助我们更好的定义和学习Roles
.
ansible-galaxy
命令默认与https://galaxy.ansible.com
网站API通信,可以查找/下载各种社区开发的 Ansible
角色
ansible-galaxy
在 Ansible 1.4.2
就已经被默认包含了.
查询并下载需要的Roles
##安装选择的角色
ansible-galaxy install geerlingguy.nginx
##安装本地角色
vim install_apache_role.yml
---
- src: file:///mnt/apache.tar.gz
name: Apache
ansible-galaxy install -r install_apache_role.yml