ansible角色的使用方法介绍


一、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		##用于测试角色

在这里插入图片描述

role存放的路径在配置文件ansible.cfg中定义:

roles_path = path/roles  
(默认目录:/etc/ansible/roles)

在这里插入图片描述

创建目录结构:

$ ansible-galaxy init apache
$ ansible-galaxy list 

在这里插入图片描述
在这里插入图片描述

三、playbook中使用roles

playbook中使用roles:

---
- hosts: server2
  roles:
    - role: role1
    - role: role2
      var1: value1		##此处变量会覆盖roles中的定义变量

控制任务执行顺序:

---
- hosts: server2
  roles:
    - role: role1	##角色任务
  pre_tasks:		##角色执行前执行的play
    - tasks1
  tasks:		##普通任务
    - tasks2
  post_tasks:		##在角色和普通任务执行完毕后执行的play
    - tasks3
  handlers:

角色:将完整的playbook拆分开

实例

default   www.westos.com  page
www.westos.com    /var/www
  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值