如何在命令行中传递变量到ansible playbook ? 下面的命令不起作用:

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

django_fixtures是我的变量。


当前回答

你可以使用——extra-vars选项。查看文档

其他回答

出于某种原因,上面的答案对我都不起作用。因为我需要在Ansbile 2.2.0中传递几个额外的变量到我的剧本中,这是我如何让它工作的(注意每个变量之前的-e选项):

ansible-playbook site.yaml -i hostinv -e firstvar=false -e second_var=value2

你可以使用——extra-vars选项。查看文档

 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"

注意:在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}}"

如果你想使用shell环境变量,这也适用于我:

Ansible-playbook -i "localhost," ldap。yaml——extrapvars ="LDAP_HOST={{lookup('env', 'LDAP_HOST')}} clustername=mycluster env=dev LDAP_USERNAME={{lookup('env', 'LDAP_USERNAME')}} LDAP_PASSWORD={{lookup('env', 'LDAP_PASSWORD')}}"