我是ansible的新手,不知道如何做到这一点,因为下面的操作行不通
ansible-playbook -i '10.0.0.1,' yada-yada.yml --tags 'loaddata' django_fixtures="tile_colors"
django_fixtures是我的变量。
django_fixtures
你可以使用--extra-vars选项。查看文档
--extra-vars
阅读文档,我找到了在命令行上传递变量部分,给出了这个例子:
ansible-playbook release.yml --extra-vars "version=1.23.45 other_variable=foo"
其他示例演示如何从JSON字符串(≥1.2)或文件(≥1.3)加载
1.2
1.3
ansible-playbook release.yml -e "version=1.23.45 other_variable=foo"
出于某种原因,上面的答案对我都不起作用。因为我需要在Ansbile 2.2.0中传递几个额外的变量到我的剧本中,这是我如何让它工作的(注意每个变量之前的-e选项):
ansible-playbook site.yaml -i hostinv -e firstvar=false -e second_var=value2
其他答案说明了如何传入命令行变量,但没有说明如何访问它们,所以如果你这样做:
--extra-vars "version=1.23.45 other_variable=foo"
在你的yml文件中,你可以通过如下方式将这些变量赋值给有范围的ansible变量:
vars: my_version: "\{\{ version }}" my_other_variable: \{\{ other_variable }}
使用命令行参数的另一种选择是利用已经在会话中定义的环境变量,你可以在你的ansible yml文件中引用这些变量,如下所示:
vars: my_version: "\{\{ lookup('env', 'version') }}" my_other_variable: \{\{ lookup('env', 'other_variable') }}
ansible-playbook test.yml --extra-vars "arg1=${var1} arg2=${var2}"
在yml文件中,您可以像这样使用它们
--- arg1: "\{\{ var1 }}" arg2: "\{\{ var2 }}"
而且,--extra-vars和-e是相同的,你可以使用其中一个。
-e
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`
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}}"
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命令中将值传递给变量时,不要使用倒逗号
如果你想使用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中,我们可以在运行剧本时通过--extra-vars(或-e)参数在命令行传递变量来定义变量。
以下是在命令行中将变量传递给Ansible剧本的一些方法:
ansible-playbook site.yml --extra-vars "arg1=demo1 arg2=demo2"
ansible-playbook site.yml --extra-vars '{"arg1":"demo1","arg2":"demo2"}'
site.yml的剧本将是:
site.yml
--- - name: ansible playbook to print external variables hosts: localhost connection: local tasks: - name: print values ansible.builtin.debug: msg: "variable1 = \{\{ arg1 }}, variable2 = \{\{ arg2 }}" when: arg1 is defined and arg2 is defined
如果您有很多特殊字符,请使用包含变量定义的JSON或YAML文件。
ansible-playbook site.yml --extra-vars "@vars.json"
vars.json文件:
vars.json
{ arg1: "demo1", arg2: "demo2" }