高级剧本语法

此页上的高级 YAML 语法示例使您可以更好地控制 Ansible 使用的 YAML 文件中放置的数据。您可以在官方 PyYAML 文档中找到有关 Python 特定 YAML 的其他信息。

不安全或原始字符串

在处理查找插件返回的值时,Ansible 使用一种名为 unsafe 的数据类型来阻止模板化。将数据标记为不安全可以防止恶意用户滥用 Jinja2 模板在目标计算机上执行任意代码。Ansible 的实现确保不安全的值永远不会被模板化。它比使用 {% raw %} ... {% endraw %} 标签转义 Jinja2 更全面。

您可以在定义的变量中使用相同的 unsafe 数据类型,以防止模板化错误和信息泄露。您可以将 vars_prompts 提供的变量值标记为不安全。您还可以在剧本中使用 unsafe。最常见的用例包括允许特殊字符(如 {%)的密码,以及看起来像模板但不应被模板化的 JSON 参数。例如

---
mypassword: !unsafe 234%234{435lkj{{lkjsdf

在剧本中

---
hosts: all
vars:
  my_unsafe_variable: !unsafe 'unsafe % value'
tasks:
    ...

对于复杂变量(如哈希或数组),请在各个元素上使用 !unsafe

---
my_unsafe_array:
  - !unsafe 'unsafe element'
  - 'safe element'

my_unsafe_hash:
  unsafe_key: !unsafe 'unsafe value'

YAML 锚点和别名:共享变量值

YAML 锚点和别名可帮助您定义、维护和灵活使用共享变量值。您可以使用 & 定义锚点,然后使用别名引用它,别名用 * 表示。这是一个示例,它使用锚点设置三个值,使用别名使用其中两个值,并覆盖第三个值

---
...
vars:
  app1:
    jvm: &jvm_opts
      opts: '-Xms1G -Xmx2G'
      port: 1000
      path: /usr/lib/app1
  app2:
    jvm:
      <<: *jvm_opts
      path: /usr/lib/app2
...

在此处,app1app2 使用锚点 &jvm_opts 和别名 *jvm_opts 共享 optsport 的值。path 的值通过 <<merge 操作符合并。

锚点和别名还允许您共享复杂的变量值集,包括嵌套变量。如果您有一个变量值包含另一个变量值,则可以分别定义它们

vars:
  webapp_version: 1.0
  webapp_custom_name: ToDo_App-1.0

这效率低下,并且在规模上意味着更多的维护。要在名称中包含版本值,您可以在 app_version 中使用锚点,在 custom_name 中使用别名

vars:
  webapp:
      version: &my_version 1.0
      custom_name:
          - "ToDo_App"
          - *my_version

现在,您可以在 custom_name 的值中重用 app_version 的值,并在模板中使用该输出

---
- name: Using values nested inside dictionary
  hosts: localhost
  vars:
    webapp:
      version: &my_version 1.0
      custom_name:
        - "ToDo_App"
        - *my_version
  tasks:
  - name: Using Anchor value
    ansible.builtin.debug:
      msg: My app is called "{{ webapp.custom_name | join('-') }}".

您已使用 &my_version 锚点锚定了 version 的值,并使用 *my_version 别名重用了它。锚点和别名允许您访问字典内部的嵌套值。

另请参阅

使用变量

关于变量的一切

操作数据

在 Ansible 中进行复杂的数据操作

沟通

有疑问?需要帮助?想分享你的想法?请访问 Ansible 通信指南