ansible--變量

ansible中的變量主要來源於如下幾種場景:
node

  1. Inventory(host vars,group vars)
    python

  2. playbook裏面mysql

  3. 命令行ios

  4. playbook執行task過程當中產生結果,能夠register起來,做爲變量給下面的task使用
    sql

  5. roles裏面shell

  6. 來自於nodes上面的factsjson


其中1-4通常來講都是用戶本身定義的,而5和facts則主要是ansible從nodes上面拉取過來,固然facts也能夠本身定義。網絡

Inventory裏面的變量
ide

/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

再看看,執行結果

wKioL1OydZiR2Sv-AAHVPuAM0dU904.jpg

相關文章
相關標籤/搜索