Я новачок у ansible і цікавлюсь, як це зробити, якби наступні не спрацювали
ansible-playbook -i '10.0.0.1,' yada-yada.yml --tags 'loaddata' django_fixtures="tile_colors"
Де django_fixtures
моя змінна.
Я новачок у ansible і цікавлюсь, як це зробити, якби наступні не спрацювали
ansible-playbook -i '10.0.0.1,' yada-yada.yml --tags 'loaddata' django_fixtures="tile_colors"
Де django_fixtures
моя змінна.
Відповіді:
Читаючи документи, я знаходжу розділ « Передача змінних у командному рядку» , який дає цей зразок:
ansible-playbook release.yml --extra-vars "version=1.23.45 other_variable=foo"
Інші приклади демонструють, як завантажити з рядка JSON (≥ 1.2
) або файлу (≥ 1.3
)
key=value
синтаксису, інтерпретуються як рядки . Використовуйте формат JSON, якщо вам потрібно передати все, що не повинно бути рядком (булеві числа, цілі числа, плавці, списки тощо). Наприклад:--extra-vars '{"i_wasted_30_mins_debugging_a_boolean_string":true}'
Інші відповіді вказують, як передавати змінні в командному рядку, але не про те, як отримати доступ до них, тож якщо це зробити:
--extra-vars "version=1.23.45 other_variable=foo"
У своєму yml-файлі ви призначаєте ці масштабовані відповідальні змінні, виконуючи щось на кшталт:
vars:
my_version: "{{ version }}"
my_other_variable: {{ other_variable }}
Альтернативою для використання аргументів командного рядка є використання змінних навколишнього середовища, які вже визначені у вашому сеансі, ви можете посилатись на них у своїх файлах ansible yml таким чином:
vars:
my_version: "{{ lookup('env', 'version') }}"
my_other_variable: {{ lookup('env', 'other_variable') }}
lookup('env', SOMETHING)
відповідає 12 коефіцієнту.
version: {{ version }}
неправильно, як і визначення version
себе.
ansible-playbook release.yml -e "version=1.23.45 other_variable=foo"
-e
Прапор коротка форма--extra-vars
--extra-vars "@some_file.json"
--extra-vars
прапор для передачі змінних, які не є у файлі. Наприклад--extra-vars "@some_file.json" --extra-vars "other_variable=foo"
Можна скористатися --extra-vars
опцією. Дивіться документи
Чомусь жоден із зазначених вище відповідей не працював на мене. Оскільки мені потрібно передати кілька додаткових варіантів моїй програмі в програмі Ansbile 2.2.0, ось так я працював (зверніть увагу на варіант -e перед кожним var):
ansible-playbook site.yaml -i hostinv -e firstvar=false -e second_var=value2
-e
це коротка форма--extra-vars
-e
прапорі
-e "firstvar=false second_var=value2"
ansible-playbook test.yml --extra-vars "arg1=${var1} arg2=${var2}"
У файлі yml ви можете їх використовувати так
---
arg1: "{{ var1 }}"
arg2: "{{ var2 }}"
Також, --extra-vars
і -e
вони однакові, ви можете використовувати один з них.
s3_sync:
bucket: ansible-harshika
file_root: "{{ pathoftsfiles }}"
validate_certs: false
mode: push
key_prefix: "{{ folder }}"
тут використовуються змінні, названі як "atoftsfiles "і" folder ". Тепер значення цій змінній може бути задано командою нижче
sudo ansible-playbook multiadd.yml --extra-vars "pathoftsfiles=/opt/lampp/htdocs/video/uploads/tsfiles/$2 folder=nitesh"
Примітка. Не використовуйте перевернуті коми, передаючи значення змінній в команді 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}}"
Це також працювало для мене, якщо ви хочете використовувати змінні середовища оболонки:
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"
Ви можете скористатись вищевказаною командою в поданих нижче ігрових книгах.
---
- 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
, перекриє змінні (-і), визначені (-і) в програмі.