Ansible 运行带有\u项的内部带有\u项
我当前正在运行一个命令,如下所示:Ansible 运行带有\u项的内部带有\u项,ansible,Ansible,我当前正在运行一个命令,如下所示: name: Generate a timed-based code for user command: "{{ item.command }} creates={{ item.file}}" with_items: - { command: '/usr/bin/google-authenticator -t -f -d --label=user1 --qr-mode=ANSI -r 3 -R 30 -w 1 --secret=/home/use
name: Generate a timed-based code for user
command: "{{ item.command }} creates={{ item.file}}"
with_items:
- { command: '/usr/bin/google-authenticator -t -f -d --label=user1 --qr-mode=ANSI -r 3 -R 30 -w 1 --secret=/home/user1/.google_authenticator', file: '/home/user1/.google_authenticator' }
- { command: '/usr/bin/google-authenticator -t -f -d --label=user2 --qr-mode=ANSI -r 3 -R 30 -w 1 --secret=/home/user2/.google_authenticator', file: '/home/user2/.google_authenticator' }
这工作正常,但根本不干燥
我正在尝试第二次与\u items
类似的角色:
- include_vars: main.yml
- name: Generate a timed-based code for user
command: "{{ item.command }} creates={{ item.file }}"
with_items:
- { command: '/usr/bin/google-authenticator -t -f -d --label="{{ item.username }}" --qr-mode=ANSI -r 3 -R 30 -w 1 --secret=/home/"{{ item.username }}"/.google_authenticator', file: '/home/"{{{ item.username }}"/.google_authenticator' }
with_items: "{{ users }}"
become: true
内部vars/main.yml
我有:
---
users:
username: user1
username: user2
username: user3
在运行剧本时,我会看到:
[WARNING]: While constructing a mapping from /Users/bshutter/Dev/server/roles/googlemfa/tasks/main.yml, line 55, column 3, found a duplicate dict key (with_items). Using last
defined value only.
[WARNING]: While constructing a mapping from /Users/bshutter/Dev/server/roles/googlemfa/vars/main.yml, line 4, column 3, found a duplicate dict key (username). Using last defined
value only.
当它运行角色并进入任务时,为用户生成基于时间的代码
TASK [googlemfa : Generate a timed-based code for user] **************************************
fatal: [10.1.10.36]: FAILED! => {"failed": true, "msg": "the field 'args' has an invalid value, which appears to include a variable that is undefined. The error was: 'ansible.vars.unsafe_proxy.AnsibleUnsafeText object' has no attribute 'file'\n\nThe error appears to have been in '/Users/bshutter/Dev/server/roles/googlemfa/tasks/main.yml': line 55, column 3, but may\nbe elsewhere in the file depending on the exact syntax problem.\n\nThe offending line appears to be:\n\n\n- name: Generate a timed-based code for user\n ^ here\n"}
我不确定我是否完全理解您的问题,因为看起来您只有一种类型的命令要运行。 因此,如果您真的只需要运行google authenticator命令,我会这样做:
- name: Generate a timed-based code for user
command: '/usr/bin/google-authenticator -t -f -d --label="{{item}}" --qr-mode=ANSI -r 3 -R 30 -w 1 --secret=/home/{{item}}' creates='/home/{{{ item }}/.google_authenticator'
with_items: "{{ users }}"
become: true
你可能正在寻找
但是,使用创建选项将很难实现,因为只有一个命令将创建该文件。还要注意,循环必须是不同的——您不能从一个列表引用另一个列表。这实际上是完美的。因为我硬编码了用户名,所以我非常热衷于使用命令来执行
,这样就不需要再运行多个命令了。