Я новичок в возможности и задаюсь вопросом, как это сделать, поскольку следующее не работает.
ansible-playbook -i '10.0.0.1,' yada-yada.yml --tags 'loaddata' django_fixtures="tile_colors"
Где django_fixtures
- моя переменная.
Я новичок в возможности и задаюсь вопросом, как это сделать, поскольку следующее не работает.
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
)
В других ответах указывается, как передавать переменные командной строки, но не как обращаться к ним, поэтому если вы выполните:
--extra-vars "version=1.23.45 other_variable=foo"
В вашем yml файле вы назначаете их для охваченных переменных переменных, делая что-то вроде:
vars:
my_version: "{{ version }}"
my_other_variable: {{ other_variable }}
Альтернативой использованию аргументов командной строки является использование переменных среды, которые уже определены в вашем сеансе, вы можете ссылаться на них в своих похожих файлах yml следующим образом:
vars:
my_version: "{{ lookup('env', 'version') }}"
my_other_variable: {{ lookup('env', 'other_variable') }}
ansible-playbook release.yml -e "version=1.23.45 other_variable=foo"
Вы можете использовать опцию --extra-vars
. Смотрите документы
По какой-то причине ни один из вышеперечисленных ответов не работал у меня. Поскольку мне нужно передать несколько дополнительных vars в мою книгу в Ansbile 2.2.0, вот как я ее заработал (обратите внимание на параметр -e перед каждым var):
ansible-playbook site.yaml -i hostinv -e firstvar=false -e second_var=value2
ansible-playbook test.yml --extra-vars "arg1=${var1} arg2=${var2}"
В файле YML вы можете использовать их, как это
---
arg1: "{{ var1 }}"
arg2: "{{ var2 }}"
Также, --extra-vars
и -e
одинаковы, вы можете использовать один из них.
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-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'
s3_sync:
bucket: ansible-harshika
file_root: "{{ pathoftsfiles }}"
validate_certs: false
mode: push
key_prefix: "{{ folder }}"
здесь используются переменные с именами 'pathoftsfiles' и 'folder'. Теперь значение этой переменной может быть задано командой ниже
sudo ansible-playbook multiadd.yml --extra-vars "pathoftsfiles=/opt/lampp/htdocs/video/uploads/tsfiles/$2 folder=nitesh"
Примечание. Не используйте кавычки при передаче значений переменной в команде оболочки
Это также сработало для меня, если вы хотите использовать переменные окружения оболочки:
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') }}"