ansible中的變量主要來源於如下幾種場景:
node
Inventory(host vars,group vars)
python
playbook裏面mysql
命令行ios
playbook執行task過程當中產生結果,能夠register起來,做爲變量給下面的task使用
sql
roles裏面shell
來自於nodes上面的factsjson
其中1-4通常來講都是用戶本身定義的,而5和facts則主要是ansible從nodes上面拉取過來,固然facts也能夠本身定義。網絡
/etc/ansible/hosts測試
[salt]
salt-master http_port=80 ##主機變量
10.240.162.112 ansible_connection=paramiko
[salt:vars] ##組變量
mysql_port=3306
/etc/ansible/host_vars/salt-master ##定義在文件裏主機變量,文件名和主機名要一致
lxc:lixc
/etc/ansible/group_vars/salt ##定義在文件裏的組變量,文件名要和組名一致
lss:
- liss
- ansible
playbooks裏面的變量
---
- hosts: all
user: lixc
vars:
time: 120 ##變量
port: 80
keeplive: 100
vars_files:
- /vars/test.yml ##也能夠導入外部的文件裏的變量
playbooks裏面能夠定義變量,也能夠導入外部的文件裏面的變量
命令行裏面的變量
命令行,傳遞變量給playbooks大概有三種方式
第1種方式,比較簡單了。
cat command_vars.yml
---
- hosts: salt-master
remote_user: '`uservar`' ##命令行變量
tasks:
- name: run this command and ignore the result
shell: echo `echovar`
- debug: msg='`result`.`stdout`'
ansible-playbook command_vars.yml -e "uservar=lixc echovar=hellomysql" ##傳入變量參數
第2種方式,以json的格式傳遞變量。
ansible-playbook command_vars.yml -e '{"uservar":"lixc", "echovar":"hellomysql"}'
##變量形式較複雜的時候,用json格式較方便,通常的直接用第一種方式就能夠了
第3種方式,傳入json文件。第二種,第三種方法,通常用於變量形式較複雜的狀況。不過,通常估計不多用,由於在命令行傳變量原本就很少用吧,仍是第一種命令行傳遞方式稍微經常使用點。
cat test.json ##json文件
uservar: lixc
echocar: hellomysql
ansible-playbook command_vars.yml -e '@test.json' ##用@加上json文件
第4種方式,register task的結果,做爲變量,給下面的task使用
---
- hosts: slat-master
tasks:
- name: test
command: ls /home
register: result
- debug: msg='`result`.`stdout`'
第五種方式,在roles裏定義。
├── group_vars ##全局組變量
│ └── salt
├── hosts
├── roles
│ ├── mysql
│ │ ├── handlers
│ │ │ └── main.yml
│ │ ├── tasks
│ │ │ ├── configure.yml
│ │ │ └── main.yml
│ │ ├── templates
│ │ │ └── my.cnf
│ │ └── vars ##當前role變量
│ │ └── main.yml
第六種方方式,從nodes獲取facts,facts和salt-stack裏面的grains差很少,主要是nodes自己的一個系統信息,bios信息,網絡,硬盤等等信息。不過,facts比salt-stack中的grains獲取的信息。要更多一些。
ansible slat-master -m setup|wc -l ##查看facts
284
salt ‘*’ grains.items|wc -l ##查看grains
65
自定義facts
自定義facts有多種方法,有能力的同窗,能夠直接去修改,setup這個模塊。不過官方的東西,我們仍是不要隨便改了。
第二種方法,定義在nodes上面,默認定義在/etc/ansible/fact.d/*fact裏面。
定義文件的格式,大概三種,分別是ini格式,json格式,或者可執行文件,不過他們返回的必須是json格式。
lixc.fact
{"json":["hello","world"]} ##這個文件內容是json格式
lss.fact
#!/usr/bin/env python ##這個文件是python腳本,返回json格式的字典
import json
dic = {"ansible_addresses": ["10.240.161.139","192.168.115.164"]}
print json.dumps(dic)
lxc.fact
[ini] ##ini格式
lixc=hello
lss=world
在node上建立文件夾並把測試的fact文件傳送過去。修改lss.fact這個文件的屬性爲其它組可執行的權限,不然待會執行不了,用-s參數試了下,也執行不了
ansible salt-master -a "mkdir -p /etc/ansible/fact.d" -s
for file in `ls `;do ansible salt-master -m copy -a "src=${file} dest=/etc/ansible/facts.d/" -s;done >/dev/null
ansible salt-master -m file -a "dest/etc/ansible/facts.d/lss.fact mode=755" > /dev/null -s
##上述有修改python腳本屬性,待會要執行
ansible salt-master -m setup -a "filter=ansible_local"
自定義模塊,只不過這個模塊,返回一個facts格式的結果罷了。
在ansible的module裏面,自定義一個文件夾,放本身的module,而後丟給自定義的module進去
mkdir /usr/share/ansible/custom
cat chengge
#!/usr/bin/env python
import json
dic = {"ansible_facts": {'chengge': 'Hello ansible','liss': "Hello salt=stack"}}
print json.dumps{dic}
##字典的key要爲ansible_facts,要否則playbooks裏不能用facts了
cp chengge /usr/share/ansible/custom
ansible salt-master -m chengge
具體如何使用自定義模塊:
其實,咱們想用模塊裏返回的facts,那麼顯然,咱們使用以前,確定要先執行如下咱們自定義的module
先看看playbooks
---
- hosts: slat-master
tasks:
- name: test custom module
action: chengge ##先執行下自定義module
- debug: msg='`chengge`' ##使用facts
再看看,執行結果