一、ROLES 角色
1、目录层级结构
2、角色调用
3、层级结构展示
示例1:利用ansible角色安装nginx
示例2:变量调用
示例3:在playbook调用角色方法:传递变量给角色
示例4:条件测试角色调用
示例5:角色安装
示例6:角色变量调整memcached内存大小
对于以上所有的方式有个弊端就是无法实现复用假设在同时部署Web、db、ha 时或不同服务器组合不同的应用就需要写多个yml文件。很难实现灵活的调用。。
roles 用于层次性、结构化地组织playbook。roles 能够根据层次型结构自动装载变量文件、tasks以及handlers等。要使用roles只需要在playbook中使用include指令即可。简单来讲,roles就是通过分别将变量(vars)、文件(file)、任务(tasks)、模块(modules)及处理器(handlers)放置于单独的目录中,并可以便捷地include它们的一种机制。角色一般用于基于主机构建服务的场景中,但也可以是用于构建守护进程等场景中。
1、目录层级结构
roles每个角色中,以特定的层级目录进行组织
Mysql/ 角色
Files/ #存放有copy或script模块等调用的文件;’
Tepmlates/ #template模块查找所需要模板文件目录;
Tasks/ #定义任务;至少应该包含一个名为main.yml的文件;其他的文件需要在此文件中通过
include进行包含。
Handlers/ #定义触发器;至少应该包含一个名为main.yml的文件;其他的文件需要在此文件中通过
Vars/ #定义变量;至少应该包含一个名为main.yml的文件;其他的文件需要在此文件中通过
Meta/ #定义变量;至少应该包含一个名为main.yml的文件;定义当前角色的特殊设定及其依赖
关系;其他的文件需要在此文件中通过include进行包含。
Default/ #设定默认变量时使用此目录中的main.yml文件。
2、角色调用
3、层级结构展示
示例1:利用ansible角色安装nginx
示例2:变量调用
示例3:在playbook调用角色方法:传递变量给角色
示例4:条件测试角色调用
示例5:角色安装
示例6:角色变量调整memcached内存大小