ansible變量的定義
1. ansible facts
facts組件是用來收集被管理主機節點信息的,使用setup模塊可以獲取這些信息。
使用方法:
ansible abc -m setup
收集到的信息非常多,這里就不顯示出來了。使用filter可以篩選指定的facts信息。
例如:
ansible abc -m setup -a 'filter=ansible_virtualization_role'
同時,我們也能在遠程主機上自定義一些信息,同樣被setup搜集到。自定義的信息需要放到遠程主機的/etc/ansible/facts.d/目錄下,並且規定,存放信息必須寫在“.fact“為后綴文件中。
--- tasks: apt: update_cache: yes upgrade: yes when: (ansible_os_family == 'Ubuntu' or ansible_os_family == 'Debian') #在這里使用了ansible_os_family信息判斷遠程主機是否為Ubuntu或者Debian系統,如果是,則執行apt命令。在when里面可以使用“and”,“or”,“not”
2. ansible-playbook中定義變量的方式有很多種,下面分別寫一下:
2.1 register注冊變量
使用register選項,可以將當前task的輸出結果賦值給一個變量。例如,下面的示例中將echo的結果"haha"賦值給say_hi變量。注意,模塊的輸出結果是json格式的,所以,引用變量時要指定引用的對象。
- hosts: abc remote_user: root vars: - package: httpd - service: httpd become: yes #2.6版本以后的參數,之前是sudo,意思為切換用戶運行 become_user: root #指定sudo用戶為mysql roles: - twtest tags: - only0 tasks: - shell: echo haha register: say_hi - debug: var=say_hi.stdout
2.2 set_fact定義變量
set_fact和register的功能很相似,也是將值賦值給變量。它更像shell中變量的賦值方式,可以將某個變量的值賦值給另一個變量,也可以將字符串賦值給變量。
- hosts: abc remote_user: root vars: - package: httpd - service: httpd become: yes #2.6版本以后的參數,之前是sudo,意思為切換用戶運行 become_user: root #指定sudo用戶為mysql roles: - twtest tags: - only0 tasks: - shell: echo haha_v1.1 register: say_hi - set_fact: var1="{{say_hi.stdout}}" - set_fact: var2="your name is" - debug: msg="{{var2}} {{var1}}"
2.3 vars定義變量
可以在play或task層次使用vars定義字典型變量。如果同名,則task層次的變量覆蓋play層次的變量。
--- - hosts: localhost vars: var1: value1 var2: value2 tasks: - debug: msg="{{var1}} {{var2}}" vars: var2: value2.2
2.4 vars_files定義變量
和vars一樣,只不過它是將變量以字典格式定義在獨立的文件中,且vars_files不能定義在task層次,只能定義在play層次。
--- - hosts: localhost vars_files: - /tmp/var_file1.yml - var_file2.yml tasks: - debug: msg="{{var1}} {{var2}}"
上面var_file2.yml使用的是相對路徑,基於playbook所在的路徑。例如該playbook為/tmp/x.yml,則var_file2.yml也應該在/tmp下。當然,完全可以使用絕對路徑。
2.5 借助with_items疊加變量,實現迭代列表
--- - hosts: localhost remote_user: root tasks: - name: test # shell: echo "{{item}}" with_items: - haha - heihei - hehe register: hi_var - debug: var=hi_var.results[0].stdout - debug: var=hi_var.results[1].stdout - debug: var=hi_var.results[2].stdout

每次迭代的過程中,調用item的模塊都會將結果保存在一個key為results的數組中。因此,引用迭代后注冊的變量時,需要在變量名中加上results,並指定數組名。例如上面的hi_var.results[N].stdout。
還可以使用for循環遍歷列表。例如:

- name: test # shell: echo "{{item}}" with_items: - haha - heihei - hehe register: hi_var tags: var_hi - debug: msg="{% for i in hi_var.results %} {{i.stdout}} {% endfor %}" tags: var_hi
3.Inenvtory中主機變量和主機組變量
1.文件格式
Inventory文件遵循INI文件風格,中括號中的字符表示組名。可以將同一個主機同時歸並到多個不同的組中,此外,當如果目標主機使用了非默認的SSH端口,還可以在主機名稱之后使用冒號加端口號來標明。
192.168.92.132 # 直接列出主機 [web] 192.168.92.132 www.xxxx.com [web] db[1:4].xxxx.com # 表示 db1.xxxx.com db2.xxxx.com db3.xxxx.com db4.xxxx.com # 字母或者數字是連續的那么,可以使用列表的方式進行標識
2.主機和主機組變量
可以在 Inventory 中自定義主機時為其添加主機變量以便於在playbook中使用
[httpd]
127.0.0.1 http_port=8080 user=daxin
在inventory文件中可以為主機和主機組定義變量,不僅包括內置變量賦值,還包括自定義變量賦值。例如以下inventory文件。
192.168.92.132 ansible_ssh_port=22 var1=1 [centos7] 192.168.92.132 192.168.92.133 192.168.92.134 var1=2 [centos7:vars] var1=2.2 var2=3 [all:vars] var2=4
以下是執行結果:
shell> ansible 192.168.92.132 -i /tmp/hosts -m shell -a 'echo "{{var1}} {{var2}}"' 192.168.92.132 | SUCCESS | rc=0 >> 2 3
從結果可知,主機變量優先級高於主機組變量,給定的主機組變量優先級高於all特殊組。
除了在inventory文件中定義主機、主機組變量,還可以將其定義在host_vars和group_vars目錄下的獨立的文件中,但要求這些host_vars或group_vars這兩個目錄和inventory文件或playbook文件在同一個目錄下,且變量的文件以對應的主機名或主機組名命名。
例如,inventory文件路徑為/etc/ansible/hosts,playbook文件路徑為/tmp/x.yml,則主機192.168.92.132和主機組centos7的變量文件路徑可以為以下幾種:
- /etc/ansible/host_vars/192.168.92.132
- /etc/ansible/group_vars/centos7
- /tmp/host_vars/192.168.92.133
- /tmp/group_vars/centos7
以下為幾個host_vars和group_vars目錄下的文件內容。
shell> cat /etc/ansible/{host_vars/192.168.92.132,group_vars/centos7} \ /tmp/{host_vars/192.168.92.132,group_vars/centos7} var1: 1 var2: 2 var3: 3 var4: 4
以下為/tmp/x.yml的內容。
---
- hosts: 192.168.92.132
tasks:
- debug: msg='{{var1}} {{var2}} {{var3}} {{var4}}'
執行結果如下:
TASK [debug] ********************************************** ok: [192.168.92.132] => { "msg": "1 2 3 4" }