Ansible插件与内容集合全解析
一、Ansible角色与插件的局限性
Ansible角色在以可维护的方式组织任务、相关变量和处理程序时非常有用。从技术上讲,你可以分发Ansible插件,即用于通过新模块、过滤器、库存插件等扩展Ansible功能的Python代码。然而,将这类内容添加到角色中并不是理想的做法,因为这实际上是将Python代码和Ansible YAML放在同一个实体中,在某种程度上使角色负担过重。
二、创建第一个Ansible插件 - Jinja过滤器
在许多Ansible任务中,你可能会构建一些相对复杂的逻辑来检查一组条件。当Jinja条件语句让你的YAML文件看起来像是Python和YAML的混合体时,是时候考虑将Python逻辑提取到Ansible插件中了。
下面通过一个简单的例子来展示如何创建一个Jinja过滤器插件。假设我们有一个名为 main.yml 的剧本,其中有一个任务需要断言某个变量是否是生成的CSS中“蓝色”的有效表示:
---
- hosts: all
vars:
my_color_choice: blue
tasks:
- name: "Verify {
{ my_color_choice }} is a form of blue."
assert:
that: my_color_choice == 'blue'
当有其他有效的蓝色表示形式时,比如 #0000ff ,就需
超级会员免费看
订阅专栏 解锁全文
32

被折叠的 条评论
为什么被折叠?



