Ansible'da yeniyim ve aşağıdakilerin işe yaramadığı için nasıl yapılacağını merak ediyorum
ansible-playbook -i '10.0.0.1,' yada-yada.yml --tags 'loaddata' django_fixtures="tile_colors"
django_fixtures
Değişkenim nerede .
Ansible'da yeniyim ve aşağıdakilerin işe yaramadığı için nasıl yapılacağını merak ediyorum
ansible-playbook -i '10.0.0.1,' yada-yada.yml --tags 'loaddata' django_fixtures="tile_colors"
django_fixtures
Değişkenim nerede .
Yanıtlar:
Dokümanları okurken bu örneği veren değişkenleri komut satırında geçiriyorum:
ansible-playbook release.yml --extra-vars "version=1.23.45 other_variable=foo"
Diğer örnekler JSON dizesinden (≥ 1.2
) veya dosyadan (≥ 1.3
) nasıl yükleneceğini gösterir
key=value
Sözdizimi kullanılarak iletilen değerler dize olarak yorumlanır . Dize olmaması gereken bir şey (Booleans, integer, float, list vb.) İletmeniz gerekiyorsa JSON biçimini kullanın. Örneğin:--extra-vars '{"i_wasted_30_mins_debugging_a_boolean_string":true}'
Diğer yanıtlar, komut satırı değişkenlerini nasıl ileteceğinizi, ancak bunlara nasıl erişeceğinizi belirtmez;
--extra-vars "version=1.23.45 other_variable=foo"
Yml dosyanızda, bunları kapsamındaki ansible değişkenlere aşağıdaki gibi bir şey yaparak atarsınız:
vars:
my_version: "{{ version }}"
my_other_variable: {{ other_variable }}
Komut satırı argümanlarını kullanmanın bir alternatifi, oturumunuzda önceden tanımlanmış çevresel değişkenleri kullanmaktır, bunlara şu gibi ansible yml dosyalarınızda başvurabilirsiniz:
vars:
my_version: "{{ lookup('env', 'version') }}"
my_other_variable: {{ lookup('env', 'other_variable') }}
lookup('env', SOMETHING)
12 faktörü ile eşleştirilir.
version: {{ version }}
yanlış, version
kendi başına tanımlamak gibi .
ansible-playbook release.yml -e "version=1.23.45 other_variable=foo"
-e
Bayrak kısa şeklidir--extra-vars
--extra-vars "@some_file.json"
--extra-vars
, dosyada olmayan değişkenleri iletmek için ikinci bir bayrağa ihtiyacınız olduğunu unutmayın . Örneğin--extra-vars "@some_file.json" --extra-vars "other_variable=foo"
--extra-vars
Seçeneği kullanabilirsiniz . Dokümanlara bakın
Nedense yukarıdaki cevapların hiçbiri benim için çalışmadı. Ansbile 2.2.0 benim oyun kitabına birkaç ekstra vars geçmek gerekiyor gibi, bu nasıl çalıştığını (her var önce -e seçeneği not):
ansible-playbook site.yaml -i hostinv -e firstvar=false -e second_var=value2
-e
--extra-vars
-e
bayraklarında ek değişkenler belirtebileceğinizi göstermek için
-e "firstvar=false second_var=value2"
ansible-playbook test.yml --extra-vars "arg1=${var1} arg2=${var2}"
Yml dosyasında bunları şöyle kullanabilirsiniz
---
arg1: "{{ var1 }}"
arg2: "{{ var2 }}"
Ayrıca --extra-vars
ve -e
aynıysa, bunlardan birini kullanabilirsiniz.
s3_sync:
bucket: ansible-harshika
file_root: "{{ pathoftsfiles }}"
validate_certs: false
mode: push
key_prefix: "{{ folder }}"
burada değişkenler 'pathoftsfiles' ve 'klasör' olarak kullanılmaktadır. Şimdi bu değişkenin değeri aşağıdaki komutla verilebilir
sudo ansible-playbook multiadd.yml --extra-vars "pathoftsfiles=/opt/lampp/htdocs/video/uploads/tsfiles/$2 folder=nitesh"
Not: Değerleri kabuk komutundaki değişkene iletirken ters virgül kullanmayın
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}}"
Kabuk ortamı değişkenlerini kullanmak istiyorsanız bu da benim için çalıştı:
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"
Yukarıdaki komutu aşağıdaki oyun kitaplarında kullanabilirsiniz.
---
- 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
değişkenlerin, oynatma kitabında tanımlanan değişkenleri geçersiz kılacağını unutmayın.