Ansible INI 查询
Ansible INI lookup
我正在使用 Ansible 的查找功能查找 INI 文件中的值。这是文档中的示例:
- debug: msg="User in integration is {{ lookup('ini', 'user section=integration file=users.ini') }}"
这是我的任务:
- set_fact: aws_access_var = "{{ lookup('ini', 'AWS_ACCESS_KEY_ID section=Credentials file=/etc/boto.cfg') }}"
它们在语法上看起来相同,但我的任务失败了:
fatal: [localhost]: FAILED! => {"failed": true, "msg": "template error while templating string: unexpected char u\"'\" at 18. String: \"{{ lookup('ini', 'AWS_ACCESS_KEY_ID section"}
知道它有什么问题吗?
删除等号周围的space,因为ansible将如何解析参数。以下工作正常:
---
- hosts: 127.0.0.1
tasks:
- set_fact: aws_access_var="{{ lookup('ini', 'AWS_ACCESS_KEY_ID section=Credentials file=boto.cfg') }}"
- debug: msg="var is {{ aws_access_var }} "
或者不使用旧样式的模块调用,而是使用 YAML 样式的参数传递。它通常不太容易出错。这是多行 YAML 版本:
---
- hosts: 127.0.0.1
tasks:
- set_fact:
aws_access_var: "{{ lookup('ini', 'AWS_ACCESS_KEY_ID section=Credentials file=boto.cfg') }}"
- debug:
msg: "var is {{ aws_access_var }} "
或者单行JSON样式一:
---
- hosts: 127.0.0.1
tasks:
- set_fact: { aws_access_var: "{{ lookup('ini', 'AWS_ACCESS_KEY_ID section=Credentials file=boto.cfg') }}" }
- debug: { msg: "var is {{ aws_access_var }} " }
以上所有剧本在本质上都是等同的并且return相同的消息
我正在使用 Ansible 的查找功能查找 INI 文件中的值。这是文档中的示例:
- debug: msg="User in integration is {{ lookup('ini', 'user section=integration file=users.ini') }}"
这是我的任务:
- set_fact: aws_access_var = "{{ lookup('ini', 'AWS_ACCESS_KEY_ID section=Credentials file=/etc/boto.cfg') }}"
它们在语法上看起来相同,但我的任务失败了:
fatal: [localhost]: FAILED! => {"failed": true, "msg": "template error while templating string: unexpected char u\"'\" at 18. String: \"{{ lookup('ini', 'AWS_ACCESS_KEY_ID section"}
知道它有什么问题吗?
删除等号周围的space,因为ansible将如何解析参数。以下工作正常:
---
- hosts: 127.0.0.1
tasks:
- set_fact: aws_access_var="{{ lookup('ini', 'AWS_ACCESS_KEY_ID section=Credentials file=boto.cfg') }}"
- debug: msg="var is {{ aws_access_var }} "
或者不使用旧样式的模块调用,而是使用 YAML 样式的参数传递。它通常不太容易出错。这是多行 YAML 版本:
---
- hosts: 127.0.0.1
tasks:
- set_fact:
aws_access_var: "{{ lookup('ini', 'AWS_ACCESS_KEY_ID section=Credentials file=boto.cfg') }}"
- debug:
msg: "var is {{ aws_access_var }} "
或者单行JSON样式一:
---
- hosts: 127.0.0.1
tasks:
- set_fact: { aws_access_var: "{{ lookup('ini', 'AWS_ACCESS_KEY_ID section=Credentials file=boto.cfg') }}" }
- debug: { msg: "var is {{ aws_access_var }} " }
以上所有剧本在本质上都是等同的并且return相同的消息