Jak mogę przekazać zmienną do Ansbook Playbook w wierszu poleceń?

219

Jestem nowy w programie ans i zastanawiam się, jak to zrobić, ponieważ poniższe działania nie działały

ansible-playbook -i '10.0.0.1,' yada-yada.yml --tags 'loaddata' django_fixtures="tile_colors"

Gdzie django_fixturesjest moja zmienna.

Édouard Lopez
źródło

Odpowiedzi:

308

Czytając dokumenty, znajduję sekcję Przekazywanie zmiennych w wierszu poleceń , która daje następującą próbkę:

ansible-playbook release.yml --extra-vars "version=1.23.45 other_variable=foo"

Inne przykłady pokazują, jak ładować z ciągu JSON (≥ 1.2) lub pliku (≥ 1.3)

Édouard Lopez
źródło
33
Zauważ również, że zmienne zdefiniowane za pomocą --extra-varszastąpią zmienne zdefiniowane w podręczniku.
suma kontrolna
5
Uwaga: (z dokumentów): Wartości przekazane przy użyciu key=valueskładni są interpretowane jako ciągi znaków . Użyj formatu JSON, jeśli potrzebujesz przekazać coś, co nie powinno być ciągiem (booleany, liczby całkowite, liczby zmiennoprzecinkowe, listy itp.). Na przykład:--extra-vars '{"i_wasted_30_mins_debugging_a_boolean_string":true}'
smilin_stan
159

Inne odpowiedzi określają sposób przekazywania zmiennych wiersza poleceń, ale nie sposób dostępu do nich, więc jeśli:

--extra-vars "version=1.23.45 other_variable=foo"

W pliku yml przypisujesz je do zmiennych odpowiadających zakresowi, wykonując coś takiego:

vars:
    my_version: "{{ version }}"
    my_other_variable: {{ other_variable }}

Alternatywą dla korzystania z argumentów wiersza poleceń jest wykorzystanie zmiennych środowiskowych, które są już zdefiniowane w sesji, możesz odwoływać się do nich w plikach ansible yml w następujący sposób:

vars:
    my_version: "{{ lookup('env', 'version') }}"
    my_other_variable: {{ lookup('env', 'other_variable') }}
GreensterRox
źródło
29
Nie jesteś pewien, o czym mówisz? Moja odpowiedź rozszerza się na wcześniej zaakceptowane odpowiedzi, odwołując się do flagi wiersza poleceń --extra-vars ORAZ jak się do nich odwoływać w konfiguracji yaml. Następnie oferuję alternatywny sposób na zrobienie tego.
GreensterRox,
1
Pytanie dotyczy konkretnie przekazania zmiennej przez wiersz poleceń . Właśnie dlatego byłoby lepiej, ponieważ ma własne pytanie / odpowiedź i powiązany link. Możesz i powiązany link jako komentarz do pytania.
Édouard Lopez
43
Rozszerzona odpowiedź pomogła mi. Z pewnością wiedząc, jak odwoływać się do przekazywanych zmiennych, częściowo wiedząc, jak przekazać parametry. W przeciwnym razie nie przekażesz ich, a jedynie zadeklarujesz, że chcesz przekazać zmienną. Aby przejść przedmiot wymaga dawcy i odbiorcy. Aby przekazać zmienną, wymagana jest deklaracja parametru i użycie parametru.
conteh 13.03.17
lookup('env', SOMETHING)odpowiada współczynnikowi 12.
zx1986
1
Pamiętaj, aby zmienić nazwę zmiennej: version: {{ version }}jest błędna, podobnie jak versionsamo definiowanie .
Minh Nghĩa
41
ansible-playbook release.yml -e "version=1.23.45 other_variable=foo"
lanni654321
źródło
25
-eFlaga jest krótka forma--extra-vars
Édouard Lopez
4
Czy mogę przekazać plik zmienny?
OpsEco,
13
@AniruddhaJawanjal tak, jak--extra-vars "@some_file.json"
AlanSE
1
@OpsEco @AlanSE zauważ, że jeśli przekazujesz zmienne z pliku, potrzebujesz drugiej --extra-varsflagi, aby przekazać zmienne spoza pliku. Na przykład--extra-vars "@some_file.json" --extra-vars "other_variable=foo"
bonh
Dziękuję @bonh tego właśnie szukałem
fan
33

Możesz użyć tej --extra-varsopcji. Zobacz dokumenty

jarv
źródło
31

Z jakiegoś powodu żadna z powyższych odpowiedzi nie działała dla mnie. Ponieważ muszę przekazać kilka dodatkowych zmiennych do mojego poradnika w Ansbile 2.2.0, oto jak to działa (zwróć uwagę na opcję -e przed każdą zmienną):

ansible-playbook site.yaml -i hostinv -e firstvar=false -e second_var=value2
OpenITeX
źródło
4
-ejest krótką formą--extra-vars
Édouard Lopez
@LXCdev KohaLappi +1 za wykazanie, że można określić dodatkowe zmienne we własnej -efladze
ctlockey,
Możesz także zdefiniować wiele zmiennych za pomocą jednej flagi:-e "firstvar=false second_var=value2"
Nils Breunese
Taki sam problem. Wiele zmiennych z jedną flagą nie działałoby. Zastanawiam się dlaczego?
Bret,
14
ansible-playbook test.yml --extra-vars "arg1=${var1} arg2=${var2}"

W pliku yml możesz użyć ich w ten sposób

---
arg1: "{{ var1 }}"
arg2: "{{ var2 }}"

Ponadto, --extra-varsi -esą takie same, możesz użyć jednego z nich.

Ali Atakan
źródło
4
 s3_sync:
      bucket: ansible-harshika
      file_root: "{{ pathoftsfiles  }}"
      validate_certs: false 
      mode: push
      key_prefix: "{{ folder }}"

tutaj używane są zmienne o nazwach „pathoftsfiles” i „folder”. Teraz wartość tej zmiennej można podać za pomocą poniższego polecenia

sudo ansible-playbook multiadd.yml --extra-vars "pathoftsfiles=/opt/lampp/htdocs/video/uploads/tsfiles/$2 folder=nitesh"

Uwaga: Nie używaj odwróconych przecinków podczas przekazywania wartości do zmiennej w poleceniu powłoki

Nitesh Jain
źródło
2
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}}"
Naveen Goyal
źródło
2

Działa to również dla mnie, jeśli chcesz używać zmiennych środowiskowych powłoki:

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') }}"

użytkownik164328
źródło
1

ansible-playbok -i <inventory> <playbook-name> -e "proc_name=sshd"

Możesz użyć powyższego polecenia w poniższych podręcznikach.

---
- 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`
Rajeev Singh
źródło