1. ansible roles
1.1 ansible 角色简介
- Ansible roles 是为了层次化,结构化的组织Playbook
- roles就是通过分别将变量、文件、任务、模块及处理器放置于单独的目录中,并可以便捷地include它们
- roles一般用于基于主机构建服务的场景中,在企业复杂业务场景中应用的频率很高
- 以特定的层级目录结构进行组织的tasks、variables、handlers、templates、files等;相当于函数的调用把各个功能切割成片段来执行。
1.2 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 ##用于测试角色
1.3 role存放的路径在配置文件ansible.cfg中定义
roles_path = ~/ansible/roles (默认目录:/etc/ansible/roles)
1.4 创建目录结构
#ansible-galaxy init apache ##创建角色apache
#ansible-galaxy list ##列出
注意:只有在ansible目录下才能列出
2. playbook中使用roles
2.1
---
- hosts: server2
roles:
- role: role1
- role: role2
var1: value1 ##此处变量会覆盖roles中的定义变量
实验:
首次安装httpd,触发启动服务,火墙添加服务,若不是首次启动,不触发,更改默认发布文件为www.westos.org
脚本:
>测试:
> 结果:
2.2 控制任务执行顺序
---
- hosts: server2
roles:
- role: role1 ##角色任务
pre_tasks: ##角色执行前执行的play
- tasks1
tasks: ##普通任务
- tasks2
post_tasks: ##在角色和普通任务执行完毕后执行的play
- tasks3
handlers:
3. ansible—galaxy命令工具
3.1 基本信息:
Ansible Galaxy 是一个免费共享和下载 Ansible 角色的网站,可以帮助我们更好的定义和学习roles。
ansible-galaxy命令默认与https://galaxy.ansible.com网站API通信,可以查找、下载各种社区开发的 Ansible 角色
ansible-galaxy在 Ansible 1.4.2 就已经被包含了
在galaxy.ansible.com
网站查询roles
3.2 安装选择的角色
3.2.1 网络角色的安装
#ansible-galaxy install geerlingguy.nginx
3.2.2 本地角色的安装
#vim install_apache_role.yml #建立安装角色目录
---
- src: file:///tmp/apache.tar.gz
name: apache 以什么名称安装
# ansible-galaxy install -r install_apache_role.yml #安装角色
4. 使用系统角色
安装:
复制角色:(root用户)
cp -r /usr/share/ansible/roles/xxx /home/lee/ansible/roles/
编写时间同步yml
示例:
测试:
检测: