ansible中定义变量的若干方法

时间:2023-01-28 14:24:37

Ansible支持十几种定义变量的方式

根据优先级排序的定义方式:

  1. Inventory变量
  2. Host Facts变量
  3. Playbook变量
  4. Playbook提示变量
  5. 变量文件
  6. 命令行变量

1.Inventory变量(在主机清单配置文件中定义变量)。

# vim ~/ansible/inventory

[test]

node1 iname="nb"

[proxy]

node2

[webserver]

node[3:4]

[webserver:vars]

iname="dachui"

#备注,在node1主机后面给该主机添加变量iname,值为nb.

#给webserver组定义变量,vars是关键词不可以改变,webserver是上面定义的组

#给这个组定义变量iname="dachui"

下面编写剧本调用刚才的变量:(在剧本中需要调用变量是要使用{{}})

vim inventory_var.yml

---

- hosts: test                                                         #定义需要远程管理的主机是谁

tasks:                                                                 #剧目要完成哪些任务

- name: create a user with var                         #剧目中的第一个任务描述信息

user:                                                              #调用user模块创建用户

name: "{{ iname }}"                                      #需要创建的用户名是iname这个变量

  1. #注意事项:
  2. #在ansible剧本中当调用变量时,开始位置就调用变量,就需要在{{}}外面加双引号
  3. #如果是在后面或者中间位置调用变量{{}}外面可以不加双引号

2.Host Facts变量

  1. vim ~/ansible/facts_var.yml
  2. ---
  3. - hosts: test
  4. tasks:
  5. - name: create user.
  6. user:
  7. name: "{{ansible_hostname}}"
  8. #定义剧本,远程所有被管理主机,调用user模块,创建用户
  9. #需要创建的用户名ansible_hostname是一个ansible_facts变量
  10. #验证: 到node1主机查看是否有一个与主机名同名的用户

3)Playbook变量(使用vars关键词可以在playbook内定义变量)。

# vim ~/ansible/playbook_var.yml

---

- hosts: test

vars: #vars是关键词,用来定义变量用的

iname: heal #具体变量名是iname,值是heal

ipass: '123456' #再定义一个变量名是ipass,值是123456

#注意密码必须是字符串,需要引号

tasks: #tasks定义需要执行的任务

- name: Use variables create user. #给任务写个描述信息

user: #调用user模块创建用户

name: "{{ iname }}" #用户名的是前面定义的变量

password: "{{ ipass | password_hash('sha512') }}"

#密码是前面定义好的ipass,管道给password_hash把密码加密.

4)Playbook提示变量(根据提示输入变量的值)。

# vim ~/ansible/prompt_var.yml

---

- hosts: test

vars_prompt:                                                    #vars_prompt是关键词,定义提示变量

- name: iname                                               #通过name定义变量名为iname

prompt: "请输入用户名"                          #执行剧本时提示信息

private: no                                              #是否是隐私数据,no代表不是(屏幕可以显示)

- name: ipasswd                                            #通过name再定义变量,变量名为ipasswd

prompt: "请输入密码"                                #执行剧本时提示信息

private: yes                                             #是否是隐私数据,yes代表是(隐私数据屏幕不显示)

tasks:                                                            #定义剧本需要执行的任务

- name: Create a user.                                #定义第一个任务的描述信息

user:                                                         #调用user模块创建用户,设置用户密码

name: "{{ iname }}"                              #用户名是前面创建的变量iname

password: "{{ ipasswd | password_hash('sha512') }}"

#密码是前面定义的变量ipasswd,密码管道给password_hash加密.

执行ansible-playbook命令时使用-e参数定义变量

5.单独定义个变量文件,在playbook中用vars_files调用该文件。

 [root@control ansible]# vim ~/ansible/file_var.yml
---
- hosts: test

vars_files: variables.yml #当变量比较多时,专门定义一个文件用来存变量

tasks:

- name: create user.

user:

name: "{{ iname }}"

password: "{{ ipass | password_hash('sha512') }}"

#调用user模块创建用户

#用户名是变量文件variables.yml中定义的变量iname,密码也是变量文件中定义的变量

[root@control ansible]# vim ~/ansible/variables.yml

---

iname: cloud

ipass: '123456'

6.命令行执行ansible-playbook命令时执行-e参数定义变量
[root@control ansible]# vim ~/ansible/command_var.yml
---
- hosts: test

tasks:

- name: create user

user:

name: "{{ iname }}"

password: "{{ ipass | password_hash('sha512') }}"

[root@control ansible]# ansible-playbook command_var.yml -e iname="beth" -e ipass="123456"