Eu sou novo no ansible e gostaria de saber como fazê-lo, pois o seguinte não funcionou
ansible-playbook -i '10.0.0.1,' yada-yada.yml --tags 'loaddata' django_fixtures="tile_colors"
Onde django_fixtures
está minha variável.
Eu sou novo no ansible e gostaria de saber como fazê-lo, pois o seguinte não funcionou
ansible-playbook -i '10.0.0.1,' yada-yada.yml --tags 'loaddata' django_fixtures="tile_colors"
Onde django_fixtures
está minha variável.
Respostas:
Lendo os documentos, encontro a seção Passando variáveis na linha de comando , que fornece este exemplo:
ansible-playbook release.yml --extra-vars "version=1.23.45 other_variable=foo"
Outros exemplos demonstram como carregar da string JSON (≥ 1.2
) ou do arquivo (≥ 1.3
)
key=value
sintaxe são interpretados como seqüências de caracteres . Use o formato JSON se precisar passar algo que não deva ser uma string (booleanos, números inteiros, flutuantes, listas etc.). Por exemplo:--extra-vars '{"i_wasted_30_mins_debugging_a_boolean_string":true}'
Outras respostas indicam como passar nas variáveis da linha de comando, mas não como acessá-las, portanto, se você fizer:
--extra-vars "version=1.23.45 other_variable=foo"
No seu arquivo yml, você os atribui a variáveis ansible com escopo, fazendo algo como:
vars:
my_version: "{{ version }}"
my_other_variable: {{ other_variable }}
Uma alternativa ao uso de argumentos de linha de comando é utilizar variáveis ambientais que já estão definidas em sua sessão, você pode referenciá-las em seus arquivos yml ansible como este:
vars:
my_version: "{{ lookup('env', 'version') }}"
my_other_variable: {{ lookup('env', 'other_variable') }}
lookup('env', SOMETHING)
corresponde ao fator 12.
version: {{ version }}
está errado, como definir version
por si só.
ansible-playbook release.yml -e "version=1.23.45 other_variable=foo"
-e
bandeira é a forma abreviada de--extra-vars
--extra-vars "@some_file.json"
--extra-vars
sinalizador para passar variáveis que não estão no arquivo. Por exemplo--extra-vars "@some_file.json" --extra-vars "other_variable=foo"
Você pode usar a --extra-vars
opção Veja os documentos
Por alguma razão, nenhuma das respostas acima funcionou para mim. Como eu preciso passar vários vars extras para o meu manual no Ansbile 2.2.0, é assim que eu o faço funcionar (observe a opção -e antes de cada var):
ansible-playbook site.yaml -i hostinv -e firstvar=false -e second_var=value2
-e
é a forma abreviada de--extra-vars
-e
bandeira
-e "firstvar=false second_var=value2"
ansible-playbook test.yml --extra-vars "arg1=${var1} arg2=${var2}"
No arquivo yml, você pode usá-los assim
---
arg1: "{{ var1 }}"
arg2: "{{ var2 }}"
Além disso, --extra-vars
e -e
são os mesmos, você pode usar um deles.
s3_sync:
bucket: ansible-harshika
file_root: "{{ pathoftsfiles }}"
validate_certs: false
mode: push
key_prefix: "{{ folder }}"
aqui as variáveis estão sendo usadas nomeadas como 'pathoftsfiles' e 'folder'. Agora, o valor para essa variável pode ser dado pelo comando abaixo
sudo ansible-playbook multiadd.yml --extra-vars "pathoftsfiles=/opt/lampp/htdocs/video/uploads/tsfiles/$2 folder=nitesh"
Nota: Não use vírgulas invertidas ao passar os valores para a variável no comando shell
ansible-playbook release.yml --extra-vars "username=hello password=bye"
#you can now use the above command anywhere in the playbook as an example below:
tasks:
- name: Create a new user in Linux
shell: useradd -m -p {{username}} {{password}}"
Isso também funcionou para mim se você deseja usar variáveis de ambiente do shell:
ansible-playbook -i "localhost," ldap.yaml --extra-vars="LDAP_HOST={{ lookup('env', 'LDAP_HOST') }} clustername=mycluster env=dev LDAP_USERNAME={{ lookup('env', 'LDAP_USERNAME') }} LDAP_PASSWORD={{ lookup('env', 'LDAP_PASSWORD') }}"
ansible-playbok -i <inventory> <playbook-name> -e "proc_name=sshd"
Você pode usar o comando acima nos manuais abaixo.
---
- name: Service Status
gather_facts: False
tasks:
- name: Check Service Status (Linux)
shell: pgrep "{{ proc_name }}"
register: service_status
ignore_errors: yes
debug: var=service_status.rc`
--extra-vars
substituirão as variáveis definidas dentro do manual.