Je suis nouveau chez ansible et je me demande comment faire car les choses suivantes n'ont pas fonctionné
ansible-playbook -i '10.0.0.1,' yada-yada.yml --tags 'loaddata' django_fixtures="tile_colors"
Où django_fixtures
est ma variable.
Je suis nouveau chez ansible et je me demande comment faire car les choses suivantes n'ont pas fonctionné
ansible-playbook -i '10.0.0.1,' yada-yada.yml --tags 'loaddata' django_fixtures="tile_colors"
Où django_fixtures
est ma variable.
Réponses:
En lisant les documents, je trouve la section Passer des variables sur la ligne de commande , qui donne cet exemple:
ansible-playbook release.yml --extra-vars "version=1.23.45 other_variable=foo"
D'autres exemples montrent comment charger à partir d'une chaîne JSON (≥ 1.2
) ou d'un fichier (≥ 1.3
)
key=value
syntaxe sont interprétées comme des chaînes . Utilisez le format JSON si vous devez transmettre tout ce qui ne devrait pas être une chaîne (booléens, entiers, flottants, listes, etc.). Par exemple:--extra-vars '{"i_wasted_30_mins_debugging_a_boolean_string":true}'
D'autres réponses indiquent comment passer les variables de ligne de commande mais pas comment y accéder, donc si vous le faites:
--extra-vars "version=1.23.45 other_variable=foo"
Dans votre fichier yml, vous les affectez à des variables ansibles étendues en faisant quelque chose comme:
vars:
my_version: "{{ version }}"
my_other_variable: {{ other_variable }}
Une alternative à l'utilisation des arguments de ligne de commande est d'utiliser des variables d'environnement qui sont déjà définies dans votre session, vous pouvez les référencer dans vos fichiers yml ansible comme ceci:
vars:
my_version: "{{ lookup('env', 'version') }}"
my_other_variable: {{ lookup('env', 'other_variable') }}
lookup('env', SOMETHING)
correspond au facteur 12.
version: {{ version }}
c'est faux, comme définir version
par lui-même.
ansible-playbook release.yml -e "version=1.23.45 other_variable=foo"
-e
drapeau est la forme abrégée de--extra-vars
--extra-vars "@some_file.json"
--extra-vars
indicateur pour transmettre des variables ne figurant pas dans le fichier. Par exemple--extra-vars "@some_file.json" --extra-vars "other_variable=foo"
Vous pouvez utiliser l' --extra-vars
option. Voir les documents
Pour une raison quelconque, aucune des réponses ci-dessus n'a fonctionné pour moi. Comme j'ai besoin de passer plusieurs vars supplémentaires à mon playbook dans Ansbile 2.2.0, voici comment je l'ai fait fonctionner (notez l'option -e avant chaque var):
ansible-playbook site.yaml -i hostinv -e firstvar=false -e second_var=value2
-e
est la forme abrégée de--extra-vars
-e
drapeau
-e "firstvar=false second_var=value2"
ansible-playbook test.yml --extra-vars "arg1=${var1} arg2=${var2}"
Dans le fichier yml, vous pouvez les utiliser comme ceci
---
arg1: "{{ var1 }}"
arg2: "{{ var2 }}"
De plus, --extra-vars
et -e
sont les mêmes, vous pouvez utiliser l'un d'eux.
s3_sync:
bucket: ansible-harshika
file_root: "{{ pathoftsfiles }}"
validate_certs: false
mode: push
key_prefix: "{{ folder }}"
ici, les variables sont utilisées comme «pathoftsfiles» et «dossier». Maintenant, la valeur de cette variable peut être donnée par la commande ci-dessous
sudo ansible-playbook multiadd.yml --extra-vars "pathoftsfiles=/opt/lampp/htdocs/video/uploads/tsfiles/$2 folder=nitesh"
Remarque: N'utilisez pas les virgules inversées lors du passage des valeurs à la variable dans la commande 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}}"
Cela a également fonctionné pour moi si vous souhaitez utiliser des variables d'environnement 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"
Vous pouvez utiliser la commande ci-dessus dans les playbooks ci-dessous.
---
- 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
remplaceront les variables définies dans le playbook.