提示:文章写完后,目录可以自动生成,如何生成可参考右边的帮助文档
Ansible--6.Ansible中的角色使用
前言
一、ansible roles简介
ansible roles 角色简介:
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 | 用于测试角色 |
roles目录路径配置:
在ansible.cfg中定义,默认路径为/etc/ansible/roles
roles_path = /home/hyl/.ansible/roles
二、创建roles并使用
ansible-galaxy init westos
创建角色westos
ansible-galaxy list
列出角色
1.playbook中使用roles
cd templates ----> vim hosts.j2 写需要甬道的jinja2模板在templates目录中
cd tasks —> vim main.yml 写play在tasks目录中
cd handlers ----> vim main.yml 写触发器到handlers目录中
tree westos/ 查看角色westos的层级结构
vim ~/.ansible/test.yml 使用playbook调用roles
ansible-playbook test.yml
2.ansible-galaxy命令工具
Ansible Galaxy 是一个免费共享和下载 Ansible 角色的网站,可以帮助我们更好的定义和学习roles。
ansible-galaxy命令默认与https://galaxy.ansible.com网站API通信,可以查找、下载各种社区开发的 Ansible 角色
ansible-galaxy在 Ansible 1.4.2 就已经被包含了
在galaxy.ansible.com网站查询roles。
3.安装选择的角色
install https://galaxy.ansible.com roles
ansible-galaxy install geerlingguy.nginx
下载本地角色
vim install_local_westos.yml
ansible-galaxy install -r install_local_westos.yml
系统角色使用:
dnf install rhel-system-roles.noarch -y 安装系统变量
rpm -ql rhel-system-roles-1.0-10.el8_1.noarch 查看安装位置
cd /usr/share/ansible/roles
ansible-galaxy list 列出角色
使用系统角色:
配置该角色,以使用ntp服务 时间同步于172.25.9.250 并且启动iburst参数。
cp -pr rhel-system-roles.timesync ~/.ansible/roles/
拷贝模板到roles目录下,便于读取调用
vim roles/rhel-system-roles.timesync/README.md
查看使用方法
经查看得,只需写剧本进行相应参数限定即可完成。
vim timesync.yml
ansible-playbook timesync.yml
ansible all -m shell -a ‘cat /etc/chrony.conf’ 查看受控主机相应参数
使用系统角色配置时间同步服务已完成。