Ansible-Playbook中的变量使用

2023-05-12,,

变量名:仅能由字母、数字和下划线组成,且只能以字母开头

变量来源:

1.ansible all -m setup 远程主机的所有变量都可直接调用

#显示所有变量
ansible all -m setup
#显示特定的变量
ansible all -m setup -a 'filter=ansible_fqdn'
ansible all -m setup -a 'filter=ansible_hostname'
ansible all -m setup -a 'filter=*address*'

2.在/etc/ansible/hosts中定义

普通变量:主机组中主机单独定义,优先级高于公共变量

公共(组)变量:针对主机组中所有主机定义统一变量

3.通过命令行指定变量,优先级最高

ansible-playbook –e varname=value

4.在playbook中定义

vars:
– var1: value1
– var2: value2

5.在role中定义

变量定义:key=value

示例:http_port=80

变量调用方式:

通过{{ variable_name }} 调用变量,且变量名前后必须有空格,有时用”{{ variable_name }}”才生效
ansible-playbook –e 选项指定

ansible-playbook test.yml -e "hosts=www user=sogou"

变量调用优先级:

命令行(-e) > playbook定义 > hosts普通变量 > hosts分组变量

示例1:命令行变量赋值

vim app.yml
---
- hosts: appsrvs
remote_user: root tasks:
– name: install package
yum: name={{ pkname }}
– name: start service
service: name={{ pkname }} state=started enabled=yes # 变量赋值并执行:
ansible-playbook -e 'pkname=vsftpd' app.yml

示例2:playbook中赋值变量

vim app.yml
---
- hosts: appsrvs
remote_user: root
vars:
– pkname1: httpd
– pkname2: vsftpd tasks:
– name: install package
yum: name={{ pkname1 }}
– name: install package
yum: name={{ pkname2 }} #执行play-book
ansible-playbook app.yml
#验证
ansible appsrvs -m shell -a 'rpm -q httpd vsftpd'
#卸载
ansible appsrvs -m shell -a 'yum -y remove httpd vsftpd'

示例3:在ansible的清单文件(/etc/ansible/hosts)中定义普通变量

vim /etc/ansible/hosts
[websrvs]
192.168.30.101 httpd_port=81
192.168.30.102 httpd_port=82 vim hostname.yml
---
- hosts: websrvs
remote_user: root tasks:
– name: set hostname
hostname: name=www{{httpd_port}}.sogou.com #语法检查
ansible-playbook -C hostname.yml
#执行Playbook
ansible-playbook hostname.yml
#检查
ansible websrvs -a 'hostname'

示例4:在ansible的清单文件(/etc/ansible/hosts)中定义分组变量

vim /etc/ansible/hosts
[websrvs]
192.168.30.101 httpd_port=81
192.168.30.102 httpd_port=82 [websrvs:vars]
nodename=www
domainname=sogou.com vim hostname.yml
---
– hosts: websrvs
remote_user: root tasks:
– name: set hostname
hostname: name={{nodename}}{{http_port}}.{{domainname}} #语法检查
ansible-playbook -C hostname.yml
#执行Playbook
ansible-playbook hostname.yml
#检查
ansible websrvs -a 'hostname'

示例5:引用系统自带(setup)变量

ansible all -m setup |grep ansible_fqdn     #查看系统自带变量
vim var.yml
---
- hosts: websrvs
remote_user: root tasks:
– name: create log file
file: name=/search/{{ ansible_fqdn }}.log state=touch mode=600 owner=op_biz #语法检查
ansible-playbook -C var.yml
#执行Playbook
ansible-playbook var.yml
#检查
ansible websrvs -a 'ls -l /search'

示例6:定义变量到一个文件中

vim vars.yml
var1: httpd
var2: vsftpd vim testvar.yml
---
- hosts: websrvs
remote_user: root
vars_files:
- vars.yml tasks:
– name: install package
yum: name={{ var1 }}
– name: create file
file: name=/search/{{ var2 }}.log state=touch mode=600 owner=op_biz #语法检查
ansible-playbook -C testvar.yml
#执行Playbook
ansible-playbook testvar.yml
#检查
ansible websrvs -m shell -a 'rpm -q httpd'
ansible websrvs -m shell -a 'ls -l /search'

6.注册变量

注册变量,其实就是将操作结果,包括标准输出和标准错误输出,保存到变量中,然后再根据这个变量的内容来决定下一步的操作,在这个过程中用来保存操作结果的变量就叫注册变量。

[root@test2 playbook]# cat test.yml
--- #标记文件的开始
- hosts: all
remote_user: root
gather_facts: no #不收集对应主机的信息,这样运行会快点。
tasks:
- name: test the register variables
shell: uptime
register: results #使用关键字register声明注册变量,上面uptime命令产生的结果,存入到results中。结果是字典形式。 - name: print the register result
debug: msg="{{ results.stdout }}" #使用debug模块,打印出上面命令的输出结果。

上面的playbook执行结果如下:

[root@test2 playbook]# ansible-playbook test.yml 

PLAY [all] ******************************************************************** 

TASK: [test the register variables] *******************************************
changed: [10.0.102.212]
changed: [10.0.102.200]
changed: [10.0.102.162] TASK: [print the register result] *********************************************
ok: [10.0.102.212] => {
"msg": " 00:18:01 up 3 days, 2:56, 3 users, load average: 0.02, 0.03, 0.05" # msg的结果就是注册变量的标准输出
}
ok: [10.0.102.200] => {
"msg": " 00:18:04 up 4 days, 7:45, 3 users, load average: 0.03, 0.06, 0.05"
}
ok: [10.0.102.162] => {
"msg": " 00:18:04 up 4 days, 7:45, 3 users, load average: 0.01, 0.02, 0.05"
} PLAY RECAP ********************************************************************
10.0.102.162 : ok=2 changed=1 unreachable=0 failed=0
10.0.102.200 : ok=2 changed=1 unreachable=0 failed=0
10.0.102.212 : ok=2 changed=1 unreachable=0 failed=0 [root@test2 playbook]#

一个注册变量通常会有以下属性:

changed:任务是否对远程主机造成的变更。
delta:任务运行所用的时间。
stdout:正常的输出信息。
stderr:错误信息。
rc:返回值

显示全部全量

[@bjyf_50_20 ansible]# cat test1.yml
---
- hosts: songwanbo
remote_user: root
gather_facts: no
tasks:
- name: test the register variables
shell: uptime
register: results - name: print the register result
debug: msg="{{ results }}"
[@bjyf_50_20 ansible]#

结果

TASK [print the register result] *********************************************************
ok: [10.160.13.139] => {
"msg": {
"ansible_facts": {
"discovered_interpreter_python": "/usr/bin/python"
},
"changed": true,
"cmd": "uptime",
"delta": "0:00:00.012288",
"end": "2020-12-23 10:56:50.202287",
"failed": false,
"rc": 0,
"start": "2020-12-23 10:56:50.189999",
"stderr": "",
"stderr_lines": [],
"stdout": " 10:56:50 up 376 days, 17:56, 2 users, load average: 0.26, 0.18, 0.10",
"stdout_lines": [
" 10:56:50 up 376 days, 17:56, 2 users, load average: 0.26, 0.18, 0.10"
]
}
}

7.高阶变量

对于普通变量,在ansible命令行设定的,在hosts文件中定义的,或者在playbook中定义的等,这些都是普通变量,在引用时,可以使用使用{{ variable }}的形式。

ansible是用python语言写的,因此也支持一种叫做列表的变量,形式如下:


[root@test2 playbook]# cat test.yml
---
- hosts: all
remote_user: root
gather_facts: no
vars:
var_list: #注意形式,定义了var_list列表,取值方法和列表取值一样,不推荐使用jinja2的方法取值。
- one
- two
- three
tasks:
- name: test the list variables
shell: echo {{ var_list[0] }} #取列表中的第一个字,也就是one
register: results - name: print the register result
debug: msg="{{ results.stdout }}"

Ansible-Playbook中的变量使用的相关教程结束。

《Ansible-Playbook中的变量使用.doc》

下载本文的Word格式文档,以方便收藏与打印。