Ansible 问题:访问名称在循环中更改的变量
这是我剧本的内容:Ansible 问题:访问名称在循环中更改的变量,ansible,ansible-template,Ansible,Ansible Template,这是我剧本的内容: - name: Download checksum get_url: url: "{{ item.value.url }}.sha1" dest: "/VAR/{{ ansible_user }}/tmp/{{ item.value.dest }}.sha1" mode: 0640 timeout: 300 force: yes with_dict: "{{ packages.list }}" - name: slurp ch
- name: Download checksum
get_url:
url: "{{ item.value.url }}.sha1"
dest: "/VAR/{{ ansible_user }}/tmp/{{ item.value.dest }}.sha1"
mode: 0640
timeout: 300
force: yes
with_dict: "{{ packages.list }}"
- name: slurp checksum
slurp:
src: "/VAR/{{ ansible_user }}/tmp/{{ item.value.dest }}.sha1"
register: {{ item.value.dest }}
with_dict: "{{ packages.list }}"
- name: debug
debug:
msg: "sha1:{{ ['item']['value']['dest']['content'] | b64decode }}"
with_dict: "{{ packages.list }}"
在我的变量中,我有:
packages:
list:
package_name1:
url: http://domaine.com/package_name_src1
dest: package_name_dest1
package_name2:
url: http://domaine.com/package_name_src2
dest: package_name_dest2
.....
.....
and so on
我试图做的是下载位于中的校验和,并将其放入变量中,然后使用debug(msg)打印它。最终目的是在下载后使用get_url中的checksome变量检查校验和。如果我想把事情简单化,主要的问题是我必须做这样的事情
debug:
msg: {{ {{ item.value.dest}}.content }}
我知道这在ansible语法中是错误的也许你可以建议我解决这个问题
目前我每次都会遇到以下错误:
fatal: [server]: FAILED! => {
"msg": "The task includes an option with an undefined variable. The error was: 'list object' has no attribute 'value'\n\nThe error appears to have been in 'test.yml': line 54, column 7, but may\nbe elsewhere in the file depending on the exact syntax problem.\n\nThe offending line appears to be:\n\n\n - name: debug\n ^ here\n"
}
我也会尽量简化事情,以下是我建议的一些变化:
slurp\u var
。Ansible in each loop不会覆盖您的变量。每个循环将在slurp\u var.results
的列表数组中添加结果(示例如下)循环
---
- hosts: localhost
gather_facts: false
vars:
packages:
list:
package_name1:
url: http://domaine.com/package_name_src1
dest: file1
package_name2:
url: http://domaine.com/package_name_src2
dest: file2
tasks:
- name: slurp checksum
slurp:
src: "/tmp/{{ item.value.dest }}.sha1"
register: slurp_var
with_dict: "{{ packages.list }}"
- name: debug
debug:
msg: "sha1: {{ item.content | b64decode }}"
with_items: "{{ slurp_var.results }}"
演示运行:
[http_offline@greenhat-29 tests]$ cat /tmp/file1.sha1
c1b016a6506775492a1968a1fa703781c6d066c8
[http_offline@greenhat-29 tests]$ cat /tmp/file2.sha1
6ab7a14cf0e04c09f1a2f0f572e7d67e35fa37bd
[http_offline@greenhat-29 tests]$ ansible-playbook test.yml
PLAY [localhost] *******************************************************************************************************************************************************************************************************
TASK [slurp checksum] **************************************************************************************************************************************************************************************************
ok: [localhost] => (item={'key': 'package_name1', 'value': {'url': 'http://domaine.com/package_name_src1', 'dest': 'file1'}})
ok: [localhost] => (item={'key': 'package_name2', 'value': {'url': 'http://domaine.com/package_name_src2', 'dest': 'file2'}})
TASK [debug] ***********************************************************************************************************************************************************************************************************
ok: [localhost] => (item={'content': 'YzFiMDE2YTY1MDY3NzU0OTJhMTk2OGExZmE3MDM3ODFjNmQwNjZjOAo=', 'source': '/tmp/file1.sha1', 'encoding': 'base64', 'invocation': {'module_args': {'src': '/tmp/file1.sha1'}}, '_ansible_parsed': True, '_ansible_no_log': False, 'failed': False, 'changed': False, 'item': {'key': 'package_name1', 'value': {'url': 'http://domaine.com/package_name_src1', 'dest': 'file1'}}, '_ansible_item_result': True, '_ansible_ignore_errors': None, '_ansible_item_label': {'key': 'package_name1', 'value': {'url': 'http://domaine.com/package_name_src1', 'dest': 'file1'}}}) => {
"msg": "sha1: c1b016a6506775492a1968a1fa703781c6d066c8\n"
}
ok: [localhost] => (item={'content': 'NmFiN2ExNGNmMGUwNGMwOWYxYTJmMGY1NzJlN2Q2N2UzNWZhMzdiZAo=', 'source': '/tmp/file2.sha1', 'encoding': 'base64', 'invocation': {'module_args': {'src': '/tmp/file2.sha1'}}, '_ansible_parsed': True, '_ansible_no_log': False, 'failed': False, 'changed': False, 'item': {'key': 'package_name2', 'value': {'url': 'http://domaine.com/package_name_src2', 'dest': 'file2'}}, '_ansible_item_result': True, '_ansible_ignore_errors': None, '_ansible_item_label': {'key': 'package_name2', 'value': {'url': 'http://domaine.com/package_name_src2', 'dest': 'file2'}}}) => {
"msg": "sha1: 6ab7a14cf0e04c09f1a2f0f572e7d67e35fa37bd\n"
}
PLAY RECAP *************************************************************************************************************************************************************************************************************
localhost : ok=2 changed=0 unreachable=0 failed=0
[http_offline@greenhat-29 tests]$
需要注意的一件事是,当试图“slurp”的文件丢失时,检查slurp\u var
,然后在后续任务中添加一些when
子句
希望有帮助 谢谢^^,我如何指定从slurp_var.resultsurl:{{item.value.url}}校验和:?使用{packages.list}获取要使用的校验和的url