Я пытаюсь извлечь IP-адреса хостов, которые являются частью двух групп, и использовать их в файле конфигурации .xml.
Проблема, с которой я столкнулся, - это результат, сгенерированный выражением, используемым в шаблоне jinja. Я хочу добиться такого результата, как 10.3.5.1,10.3.5.2,10.3.5.2
но вместо этого я получаю что-то вроде [u'10.3.5.1],[u'10.3.5.2],[u'10.3.5.2]
.
Это выражение используется в шаблоне jinja:
<member1>{{ (groups['group_one']+groups['group_two']) | map('extract',hostvars,'ansible_ip_addresses') | list | unique | join(',') }}</member1>
Я также пробовал другие фильтры, но не смог получить ожидаемого результата.
Какие фильтры использовать для этого? (Я не мог найти нужные)
ansible_ip_addresses
- это список, поэтому у вас есть список (хостов) с вложенными списками (с IP-адресами).
Возможно, вы захотите разгладить его перед нанесением unique
и join
:
{{ (groups['group_one']+groups['group_two']) | map('extract',hostvars,'ansible_ip_addresses') | list | sum(start=[]) | unique | join(',') }}
Это создаст плоский список с одним IP-адресом в качестве элемента, а затем возьмет уникальные элементы и соединит их с запятой.