
Eu tenho um grupo de dois anfitriões. Quero delegar uma tarefa para aquele que não é o host atual.
O seguinte não corresponde a nada e apenas retorna uma lista dos meus dois hosts iniciais.
- debug: msg="{{ groups['web-servers'] | select('match', '^(?!\{\{\ inventory_hostname\ \}\}$).+') | list }}"
Acho que está escapando, esse é o problema, mas não consigo descobrir.
Responder1
Uma opção seria usar odiferençafiltro. Abaixo está um exemplo de como usar o filtro
shell> cat test-difference-01.yml
- hosts: localhost
gather_facts: no
vars:
web_servers:
- web-server-01
- web-server-02
- web-server-09
inventory_hostname:
- web-server-02
tasks:
- set_fact:
delegate_to_hosts: "{{ web_servers|difference(inventory_hostname) }}"
- debug:
msg : "{{ delegate_to_hosts }}"
shell> ansible-playbook test-difference-01.yml | grep -A 3 msg
"msg": [
"web-server-01",
"web-server-09"
]
P:"grupo de dois hosts ... delegar uma tarefa para aquele que não é o host atual"
Dado o inventário
shell> cat hosts
[webservers]
web-server-01
web-server-02
O manual
- hosts: webservers
tasks:
- debug:
msg: "{{ inventory_hostname }} {{ item }}"
loop: "{{ groups.webservers|difference([inventory_hostname]) }}"
delegate_to: "{{ item }}"
dá (resumido)
ok: [web-server-01 -> web-server-02] => (item=web-server-02) =>
msg: web-server-01 web-server-02
ok: [web-server-02 -> web-server-01] => (item=web-server-01) =>
msg: web-server-02 web-server-01
O código pode ser generalizado executando emtodoshosts listados emansible_play_hosts_all
- hosts: all
tasks:
- debug:
msg: "{{ inventory_hostname }} {{ item }}"
loop: "{{ ansible_play_hosts_all|difference([inventory_hostname]) }}"
delegate_to: "{{ item }}"
Responder2
Você não precisa especificar um regex com lookahead negativo. Em vez disso, use oreject
filtro.
Além disso, com equalto
test, você não precisa colocar a string em ^
and $
:
- debug:
msg: "{{ groups['web-servers'] | reject('equalto', inventory_hostname) | list }}"
Responder3
Acho que o problema está na substituição de variáveis (ou falta dela) no padrão regex. Você pode definir o padrão separadamente e passá-lo para o filtro (observe que modifiquei um pouco seu regex):
- set_fact: pattern="^(?!{{ inventory_hostname }}).+$"
- debug: msg="{{ groups['web-servers'] | select('match', pattern) | list }}"
Resultado:
TASK [debug : debug] ******************************************
ok: [foo] => {
"msg": [
"bar",
"baz"
]
}
ok: [bar] => {
"msg": [
"foo",
"baz"
]
}
ok: [baz] => {
"msg": [
"foo",
"bar"
]
}