Ansible - 从字典中获取一个键(但不是在循环中)

时间:2016-07-28 22:38:55

标签: python yaml ansible ansible-playbook

关于Ansible中词典的另一个问题!

为方便起见,我对字典中保存的mysql数据库有一定的值,可以使用with_dict循环来创建数据库和数据库用户。

mysql_dbs:
  db1:
    user: db1user
    pass: "jdhfksjdf"
    accessible_from: localhost
  db2:
    user: db2user
    pass: "npoaivrpon"
    accessible_from: localhost

任务:

- name: Configure mysql users
  mysql_user: name={{ item.value.user }} password={{ item.value.pass }} host={{ item.value.accessible_from }} priv={{ item.key }}.*:ALL  state=present
  with_dict: "{{ mysql_dbs }}"

但是,我想在另一个任务中使用其中一个字典中的密钥,但我不想遍历字典,我只想一次使用一个。我如何获取描述字典的密钥(抱歉,不确定术语)?

问题任务:

- name: Add the db1 schema
  shell: mysql {{ item }} < /path/to/db1.sql 
  with_items: '{{ mysql_dbs[db1] }}'

ansible run错误:

fatal: [myhost]: FAILED! => {"failed": true, "msg": "'item' is undefined"}

我愿意相信with_items不是最好的策略,但有没有人有什么想法是正确的?

先谢谢,暂时坚持了一段时间......

1 个答案:

答案 0 :(得分:10)

给出嵌套词典......

mysql_dbs:
  db1:
    user: db1user
    pass: "jdhfksjdf"
    accessible_from: localhost
  db2:
    user: db2user
    pass: "npoaivrpon"
    accessible_from: localhost

您可以使用点分表示法:

- debug:
    var: mysql_dbs.db1

或者您可以使用更多Python式语法:

- debug:
    var: mysql_dbs['db1']

看起来你试图使用邪恶的混合体:

mysql_dbs[db1]

在这种情况下,您尝试取消引用名为db1的变量, 这可能是不存在的并且会导致一个变量 未定义&#34;有点错误。

<强>更新

你的问题不清楚,因为在你的例子中你有......

with_items: '{{ mysql_dbs[db1] }}'

......看起来你正试图完全按照我在这里描述的那样做。如果您真正想要做的是迭代mysql_dbs字典的键,请记住它只是一个Python字典,并且您可以使用所有标准字典方法,因此:

- debug:
    msg: "key: {{ item }}"
  with_items: "{{ mysql_dbs.keys() }}"

其输出为:

TASK [debug] *******************************************************************
ok: [localhost] => (item=db1) => {
    "item": "db1", 
    "msg": "key: db1"
}
ok: [localhost] => (item=db2) => {
    "item": "db2", 
    "msg": "key: db2"
}