- ansible roles
ansible角色简介
- Ansible roles 是为了层次化,结构化的组织playbook
- roles就是通过分别将变量,文件,任务,模块及处理器放置于单独的目录中,并可以便捷的include他们
- roles一般用于基于主机构建服务的场景中,在企业复杂场景中应用个频率很高
- 以特定的层级目录结构进行组织的tasks,variables,handlers.templates,files等,相当于函数的调用把各个功能切割成片段来执行
- roles目录结构
files ##存放copy或script等模块调用的函数
tasks ##定义各种task,要有main.yml其他文件include包含调用 handlers ##定义variables,要有main.yml,其他文件include包含调用 vars ##定义variables,要有main.yml,其他文件包含调用
templates ##存储由template模块调用的模板文件
meta ##定义当前角色的特殊设定及其依赖关系,main.yml的文件 defaults ###要有main.yml 的文件用于设定默认变量
tests ##用于测试角色
- roles存放地点;路径在配置文件ansible.cfg中定义
roles_path = path/roles ##默认目录/etc/ansible/roles - 创建目录结构
ansible-galaxy init apache ##创建角色
ansible-galaxy list ##查看角色
- playbook中使用roles
---
- hosts: server2
roles:
- role: role1
- role: role2
var1: value1 ##此处变量会覆盖roles中的定义变量
- 控制变量执行顺序
---
- hosts: server2
roles:
- role: role1 ##角色任务
pre_task:
- task1 ##角色执行前执行的play
tasks:
- task2 #3普通任务
post_tasks: ##在角色和普通任务执行完毕后执行的play
- task3
handlders:
- ansible-galaxy命令工具
安装选择的角色
ansible-galaxy collection install geerlingguy.k8s
- install local roles
vim install_roles.yml
---
- src: file:///mnt/apache.tar.gz
name: westoslu
ansible-galaxy install -r install_roles.yml