1. ansible-playbook变量定义与使用
- 命令行
- 在Inventory中定义
- 在Playbook中定义
- 在Role中定义
- 注册变量(register)
- 系统信息变量(facts)
2. 在命令行中定义变量
2.1) 案例编写playbook中定义,变量命令行传参
1 [root@test-1 bin]# vim veriable.yaml
2 [root@test-1 bin]# cat veriable.yaml
3 ---
4 - hosts: web1
5 gather_facts: no
6 remote_user: root
7
8
9 tasks:
10 - name: test var
11 debug: msg="{{work_dir}}"
2.2) 执行playbook变量命令传参
1 [root@test-1 bin]# ansible-playbook veriable.yaml -e work_dir=/usr/local
2
3 PLAY [web1] ******************************************************************************************************************************************************************************************************************************************************************
4
5 TASK [test var] **************************************************************************************************************************************************************************************************************************************************************
6 ok: [192.168.200.132] => {
7 "msg": "/usr/local"
8 }
9 ok: [192.168.200.133] => {
10 "msg": "/usr/local"
11 }
12
13 PLAY RECAP *******************************************************************************************************************************************************************************************************************************************************************
14 192.168.200.132 : ok=1 changed=0 unreachable=0 failed=0 skipped=0 rescued=0 ignored=0
15 192.168.200.133 : ok=1 changed=0 unreachable=0 failed=0 skipped=0 rescued=0 ignored=0
3. 在inventory中定义变量
是在通过hosts文件里定义变量
1 [WebServer] 2 app[01:03].imzcy.cn 3 4 5 [DB] 6 db-[a:c].imzcy.com 7 8 9 192.168.109.[131:133]
4. 在Playbook中定义变量
4.1)编写Playbook定义变量
1 [root@test-1 bin]# vim playbook.yaml
2 [root@test-1 bin]# cat playbook.yaml
3 ---
4 - hosts: web1
5 gather_facts: no
6 remote_user: root
7 vars:
8 - work_dir: /usr/local
9 - nginx_version: 1.15
10
11 tasks:
12 - name: install nginx
13 debug: msg="{{work_dir}}/nginx/{{nginx_version}}"
4.2) 执行playbook配置文件语法检测
1 [root@test-1 bin]# ansible-playbook --syntax-check playbook.yaml 2 3 playbook: playbook.yaml
4.3) 执行playbook变量文件传参
1 [root@test-1 bin]# ansible-playbook playbook.yaml
2
3 PLAY [web1] ************************************************************************************************************************************
4
5 TASK [install nginx] ***************************************************************************************************************************
6 ok: [192.168.200.132] => {
7 "msg": "/usr/local/nginx/1.15"
8 }
9 ok: [192.168.200.133] => {
10 "msg": "/usr/local/nginx/1.15"
11 }
12
13 PLAY RECAP *************************************************************************************************************************************
14 192.168.200.132 : ok=1 changed=0 unreachable=0 failed=0 skipped=0 rescued=0 ignored=0
15 192.168.200.133 : ok=1 changed=0 unreachable=0 failed=0 skipped=0 rescued=0 ignored=0
5. 在Role中定义
1 [root@test-1 vars]# vim /ansible/roles/nginx/vars/main.yaml 2 [root@test-1 vars]# cat /ansible/roles/nginx/vars/main.yaml 3 --- 4 #nginx 5 nginx_version: 1.16.1 6 http_port: 80 7 server_name: test-www.scajy.cn
6. 注册变量(register)
6.1)编写register注册变量
1 [root@test-1 bin]# vim register.yaml
2 [root@test-1 bin]# cat register.yaml
3 ---
4 - hosts: web1
5 gather_facts: no
6 remote_user: root
7 vars:
8 - work_dir: /usr/local
9 - nginx_version: 1.15.1
10
11 tasks:
12 - name: register var
13 command: date +"%F_%T"
14 register: datetime
15
16 - name: touch file
17 file:
18 dest: /tmp/r_{{datetime.stdout}}
19 state: touch
6.2) 检查语法是否错误
1 [root@test-1 bin]# ansible-playbook --syntax-check register.yaml 2 3 playbook: register.yaml
6.3) 执行register配置文件
1 [root@test-1 bin]# ansible-playbook register.yaml 2 3 PLAY [web1] ************************************************************************************************************************************ 4 5 TASK [register var] **************************************************************************************************************************** 6 changed: [192.168.200.133] 7 changed: [192.168.200.132] 8 9 TASK [touch file] ****************************************************************************************************************************** 10 changed: [192.168.200.133] 11 changed: [192.168.200.132] 12 13 PLAY RECAP ************************************************************************************************************************************* 14 192.168.200.132 : ok=2 changed=2 unreachable=0 failed=0 skipped=0 rescued=0 ignored=0 15 192.168.200.133 : ok=2 changed=2 unreachable=0 failed=0 skipped=0 rescued=0 ignored=0
6.4) 验证tmp下是否创建了文件
1 [root@test-1 bin]# ansible web1 -m shell -a "ls -a /tmp |grep r_*" 2 192.168.200.132 | CHANGED | rc=0 >> 3 apache-tomcat-8.5.38.tar.gz 4 hsperfdata_root 5 r_2019-08-25_11:04:53 6 7 8 192.168.200.133 | CHANGED | rc=0 >> 9 apache-tomcat-8.5.38.tar.gz 10 hsperfdata_root 11 r_2019-08-25_11:04:53
7. 系统信息变量(facts)
1 ---
2 - hosts:webservers
3 tasks:
4 - debug:
5 msg: {{group_names}} #打印ansible的host组
6 - debug:
7 msg: {{inventory_hostname}} #打印详细的host主机
8 - debug:
9 msg: {{ansible_hostname}} #配合gather_facts: yes 开启收集系统信息
