自動化運維工具 ansible

一、ansible的主要組成部分

在這裏插入圖片描述
1、
ansible playbook:任務劇本(任務集),編排定義ansible任務集的配置文件,由ansible順序依次執行,通常是json格式的yml文件。
inventory:ansible管理主機的清單/etc/ansible/hosts
modules:ansible執行命令的功能模塊,多數爲內置核心模塊,也可自定義
plugins:模塊功能的補充,如連接類型的插件、循環插件,變量插件,過濾插件,改功能不常用
api:供第三方程序調用的應用程序編程接口
ansible:組合inventory,api,modules,plugins的綠框,可以理解爲ansible命令工具,其爲核心執行工具

2、ansible命令執行來源
user:普通用戶,即system administrator
cmdb(配置管理數據庫)api調用
public/private cloud api調用
user --> ansible playbook --> ansible

3、利用ansible實現管路的方式:
Ad-Hoc 即ansible命令。主要用於臨時命令使用場景
ansible-playbook 主要用於長期規劃好的,大型項目的場景,需要有提前的規劃

4、ansible-playbook執行過程
將已經編排好的任務集寫入ansible-playbook
通過ansible-playbook命令分拆任務集至逐條ansible命令,按預定規則逐條執行

5、ansible的主要操作對象
HOSTS主機
NETWORKING網絡設備

6、注意事項
執行ansible的主機一般稱爲主控端,中控,master或者堡壘機
主控端python版本需要在2.6或者以上
被控端python版本小魚2.4需要安裝python-simplejson
被控端如開啓SELinux需要安裝libselinux-python
Windows不能作爲主控端

二、安裝

rpm包安裝:EPEL源

yum -y install ansible

編譯安裝:

yum -y install python-jinjia2 PyYAML python-paramiko python-babel python-crypto
tar -xf ansible-1.5.2.tar.gz
cd ansible-1.5.4
python setup.py build
python setup.py install
mkdir /etc/ansible
cp -r examples/* /etc/ansible/

Git方式

 git clone git://github.com/ansible/ansible.git --recursive
cd ./ansible
source ./hacking/env-setup

pip安裝:pip是安裝python包的管理器,類似於yum

yum -y install python-pip python-devel
yum -y install gcc glib-devel zlibl-devel rpm-build openssl-devel
pip install --upgrade pip
pip install ansible --upgrade
確認安裝:ansible --version

三、相關文件

配置文件

/etc/ansible/ansible.cfg 主配置文件,ansible工作特性
/etc/ansible/hosts 主機清單
/etc/ansible/roles/ 存放角色的目錄

程序

/usr/bin/ansible 主程序,臨時命令執行工具
/usr/bin/ansible-doc 查看配置文檔,模塊功能查看工具
/usr/bin/ansible-galaxy 下載/上傳優秀代碼或者Roles模塊的官網平臺
/usr/bin/ansible-play-book 定製自動化任務,編排劇本工具 
/usr/bin/ansible-pull 遠程執行的命令的工具
/usr/bin/ansible-vault 文件加密工具
/usr/bin/ansible-console 基於Console界面與用戶交互的執行工具

主機清單inventory

inventory主機清單:ansible的主要功用在於批量主機操作,爲了方便的使用其中的部分主機,可以在inventory
file中將其分組命名 默認的inventory file爲/etc/ansible/hosts inventory
file可以有多個,且也可以通過Dynamic Inventory來動態完成 /etc/ansible/hosts文件格式
inventory文件遵循INI文件風格,中括號的字符爲組名。可以將同一個主機同事歸併到不通的組中;此外,當如若目標主機使用了非默認的ssh端口,還可以在主機名稱之後使用冒號加端口號來標明

eg:

ntp.magedu.com
[webservers]
www1.magedu.com:2222
www2.magedu.com
[dbservers]
db1.magedu.com
db2.magedu.com

如果主機名稱遵相似的命名模式,還可以使用列表的方式標識個主機
eg:

[wedservers]
www[01:100].example.com
[dbservers]
db-[a:f].example.com

四、ansible配置文件

ansible 配置文件/etc/ansible/ansible.cfg(一般保持默認)
[defaults]
#inventory      = /etc/ansible/hosts  #主機列表配置文件
#library        = /usr/share/my_modules/ #庫文件存放目錄
#module_utils   = /usr/share/my_module_utils/ 
#remote_tmp     = ~/.ansible/tmp #臨時py命令文件存放在遠程主機目錄
#local_tmp      = ~/.ansible/tmp #本機臨時命令執行目錄
#forks          = 5 #默認併發數(同時執行5個操作,eg五臺主機五臺的執行)
#poll_interval  = 15 
#sudo_user      = root #默認sudo用戶
#ask_sudo_pass = True #每次執行ansible命令是否詢問ssh密碼
#ask_pass      = True
#transport      = smart
#remote_port    = 22
#module_lang    = C
#module_set_locale = False
#host_key_checking = False #檢查對應服務的的host_key,建議取消註釋
#log_path = /var/log/ansible.log #日誌文件

在這裏插入圖片描述

五、ansible系列命令

ansible ansible-doc ansible-playbook ansible-vault ansible-console ansible-galaxy ansible-pull

1、ansible-doc 顯示模塊幫助

ansible-doc [options][module]

  • -a 顯示所有模塊文檔

  • -l,–list 列出可用模塊

  • -s,–snippet 顯示指定模塊的playbook片段

實例:

  • ansible-doc -l 列出所有模塊
  • ansible-doc ping 查看指定模塊的幫助用法
  • ansible-doc -s ping 查看指定模塊的幫助用法

ansible通過ssh實現配置管理、應用部署,任務執行等功能,建議配置ansible段能基於密鑰認證的方式聯繫各被管理節點

2、ansible<host-pattern>[-m module_name] [-a args]

–version 顯示版本
-m module 指定模塊,默認爲command
-v 詳細過程 -vv -vvv 更詳細
–list-host 顯示主機列表,可簡寫–list
-k ,–ask-pass 提示輸入ssh連接密碼。默認key驗證
-K, --ask-become-pass 提示輸入sudo時的口令
-C,–check 檢查不執行
-T --timeout=TIMEOUT 執行命令的超時時間,默認10s
-u --user=REMOTE——USER 執行遠程執行的用戶
-b, --become 代替舊版本的sudo切換

3、ansible的Host-pattern 匹配主機的列表

all:表示所有Inventory中的所有主機

*:通配符
ansible “*” -m ping
ansible 192.168.1.* -m ping
ansible “*srvs” -m ping

或關係
ansible “webserver:dbserver” -m ping
ansible "webserver:dbserver" -m ping #執行在web組並且在dbserver組中的主機(忽略重複的)

與關係
ansible "webserver:&dbserver" -m ping
只執行在web組並且也在dbserver組中的主機

邏輯非
ansible 'webserver:!dbserver' -m ping  【注意此處只能使用單引號!】

綜合邏輯
ansible 'webserver:dbserver:&webserver:!dbserver' -m ping

正則表達式
ansible "webserver:&dbserver" -m ping
ansible "~(web|db).*\.magedu.\com" -m ping

4、ansible命令執行過程

  1. 加載自己的配置文件 默認/etc/ansible/ansible.cfg
  2. 加載自己對應的模塊 如command
  3. 通過ansible將模塊或命令生成對應的臨時py文件,並將改文件傳輸至遠程服務器的對應執行用戶SHOME/.ansible/tmp/ansible-tmp-數字/XXX.py文件
  4. 文件見+x執行
  5. 執行並返回結果
  6. 刪除臨時py文件,sleep 0退出

5、執行狀態

綠色:執行成功並且不需要做改變的操作
黃色:執行成功並且對目標主機做變更
紅色:執行失敗

在這裏插入圖片描述

6、ansible常見模塊

ping:

command:在遠程主機執行命令,默認模塊。可忽略-m選項
ansible srvs -m command -a ‘systemctl restart sshd’
ansible srvs -m command -a 'echo magedu | passwd --stdin wang '不成功
此命令不支持$VRNAME< >  | ; & 等,需要用shell模塊實現

shell:和command相似,用shell執行命令
ansible srv -m shell -a ‘echo magedu | passwd --stdin wang’
調用bash執行命令 類似cat /tmp/stanley.md | awk -F '|' '{print $1,$2}' & >
/tmp/example.txt 這些複雜命令,及時使用shell也可能會失敗,解決辦法:寫到腳本時,				 copy到遠程,執行,再把需要的結果拉回執行命令的機器

script:運行腳本
-a “/PATH/TO/SCRIPT_FILE”
ansible webserver -m script -a f1.sh

copy:從服務器複製文件到客戶端
ansible all -m copy -a 'src=/data/test1 dest=/data/test1 backup=yes mode=000 owner=zhang'  ##如目標存在,默認覆蓋,此處是指先備份,並修改全向屬主
ansible all -m shell -a 'ls -l /data/'
ansible all -m copy -a "content='test content\n' dest=/tmo/f1.txt" 利用內容,直接生成目標文件

fetch:從客戶端取文件至服務器端,與copy相反,目錄可以先tar
ansible all -m fetch -a ‘src=/root/a.sh dest=/data/f2.sh'

在這裏插入圖片描述

file:設置文件屬性(狀態,屬組,屬主,權限)
ansible all -m file -a “path=/root/a.sh owner=zhang mode=755”
ansible all -m file -a 'src=/data/test1 dest=/tmp/test state=link'
ansible all -m file -a ’name=/data/f3 state=touch‘  #創建文件
ansible all -m file -a ’name=/data/f3 state=absent‘ #刪除文件
ansible all -m file -a ’name=/data state=directory‘ #創建目錄
ansible all -m file -a ’src=/etc/fstab dest=/data/fstab.link state=link‘

archive打包模塊
unarchive 解打包模塊

hostname 管理主機名
ansible 192.168.10.24 -m hostname -a “name=kso-bj6-zw-zhangwei”#永久生效(但hosts文件需要手動更改)

cron 計劃任務
支持時間:minute,hour,day,month,weekday
ansible all -m cron -a "minute=*/5 weekday=1,3,5 job='/usr/sbin/ntpfata 172.16.0.1 & >/dev/null' name=Synctime" 創建任務
ansible all -m cron -a "disabled=true job='/usr/sbin/ntpfata 172.16.0.1 & >/dev/null' name=Synctime" 禁用任務(加#號註釋)
ansible all -m cron -a "disabled=no  job='/usr/sbin/ntpfata 172.16.0.1 & >/dev/null' name=Synctime" 啓用任務
ansible all -m  cron -a 'state=absent name=Synctime' 刪除任務

yum:管理包
ansible all -m yum -a 'name=httpd state=latest'安裝
ansible all -m yum -a 'name=httpd state=ansent' 卸載
ansible all -m yum  -a 'name=dstat update_cache=yes' 更新緩存
【注:dstat--監控工具https://www.jianshu.com/p/49b259cbcc79】

service:管理服務
ansible all -m service -a 'name=httpd state=stopped'
ansible all -m service -a 'name=httpd state=started enabled=yes'
ansible all -m service -a 'name=httpd state=reload'
ansible all -m service -a 'name=httpd state=restart'

user:管理用戶
ansible all -m user -a 'name=user1 comment="test user" uid=2048 home=/data/home/user1 group=root'  創建用戶,以及uid,家目錄,並描述(comment)
ansible all -m user -a 'name=zhangwei shell=/sbin/nologin  system=yes home=/data/home/zhangwei'    創建不可登陸的系統用戶
ansible all -m user -a 'name=zhangwei state=absent remove=yes'刪除用戶及家目錄

group:管理組
ansible all -m group -a "name=testgroup system=yes"
ansible all -m group -a "name=testgroup state=absent"

ansible-doc -s moudul #簡短介紹模塊使用方法
ansible-doc modul #詳細介紹模塊使用方法

7、ansible系列命令

ansible-galaxy    鏈接:https://galaxy.ansible.com下載對應的role
列出所有已安裝的galaxy
ansible-galaxy list
安裝galaxy
ansible-galaxy install geerlingguy.redis
刪除galaxy
ansible-galaxy remove geerlingguy.redis

ansible-pull
推送命令至遠程,效率無限提升,對運維要求較高

ansible-playbook
ansible-playbook hello.yml    【書寫注意空格,行首注意對齊】
cat hello.yml 
---
# hello test yml file
- hosts: all
  remote_user: root    #遠程用戶
  tasks:
        - name: look hostname
          command: hostname


ansible-vault 管理加密解密yml文件
ansible-vault [create | decrypt | edit | encrypt | rekey | view]
ansible-vaullt encrypt hello.yml 加密
ansible-vault decrypt hello.yml 解密
ansible-vault view hello.yml 查看
ansible-vault edit hello.yml 編輯加密文件
ansible-vault rekey hello.yml 修改口令
ansible-vault create new.yml 創建新文件


ansible-console:	2.0+新增,可交互執行命令,支持tab
root@test(2)[f:10] $
執行用戶@當前操作的主機組(當前組的主機數量)[f:併發數]$
設置併發數:fock n 例如:fock 10
切換組:cd 主機組 例如:cd webserver 
列出當前組的主機列表:list
列出所有內置命令:?或help
示例:
root@all (2)[f:5]$ list
root@all (2)[f:5]$ cd webserver
root@dbserver (2)[f:5]$ list
root@dbserver (2)[f:5]$ yum name=httpd state=present
root@dbserver (2)[f:5]$ service name=httpd state=restart

8、playbook

a.playbook流程介紹
在這裏插入圖片描述

  • playbook是由一個或者多個“play”組成的列表

  • play的主要功能在於將事先歸併爲一組的主機裝扮成事先通過ansible中的task定義好的角色。從根本上來講,所謂task無非是調用ansible的一個module。將多個play組織在一個playbook中,即可以讓他們聯同起來按照事先編排的機制同唱一臺大戲。

  • palybook採用YAML預言編寫

b.yaml介紹

YAML是一個可讀性高用來表達資料序列的格式。YAML參考了其他多種語言,包括:XML、C語言、Python、Perl以及電子郵件格式RFC2822等。Clark Evans在2001年在首次發表了這種語言,另外Ingy dot Net與Oren Ben-Kiki也是這種語言的共同設計者。
YAML Ain’t Markup Language,即TAML不是XML。不過,在開發這種語言時,YAML的意思其實是:Yet Another Markup Language(仍是一種標記語言)
特性
YAML的可讀性好
YAML和腳本語言的交互性好
YAML使用實現語言的數據類型
YAML有一個一致的信息模型
YAML易於實現
YAML可以基於流來處理
YAML表達能力強,擴展性好
更多內容及規範參見http://www.yaml.org

c.YAML語法簡介
(1)注意

在單一檔案中,可以連續三個連字號(---)區分多個檔案。另外,還有選擇性的連續三個點號(...)用來表示檔案結尾
次行動開始正常些playbook的內容,一般建議些明該playbook的功能
使用#號註釋代碼
縮進必須是統一的,不能空格和tab混用
縮進的級別也必須是一致的,同樣的縮進代表同樣的級別,程序判斷配置的級別是通過縮進結合換行來實現的
YAML文件內容和linux系統大小寫判斷方式保持一致,是區別大小寫的,k/v的值均需大小寫敏感
k/v的值可同行寫也可換行寫。同行的話,使用:號分割
v可是一個字符串,也可是另一個列表
一個完成的代碼塊功能需最少元素包括 name:    task
一個name只能包括一個task
YAML文件擴展名通常爲yml或者yaml

(2)list:列表,其所有元素均使用“-”打頭

示例:
# Alist of tasty fruits
- Apple
- Orange
- Strawberry
- Mango

(3)Dictionary:字典,通常由說個key與value構成、

示例:
---
# An employee record
name:Example Developer
 job:Developer
skill:Elite
也可將key:value放置於{}中進行表示,用“,”分隔多個key:value
示例:
---
# An employee record
{name:Example Developer,job:Developer,skill:Elite}

YAML的語法和其他高階語言類似,並且可以簡單表達清單,散列表、標量等數據結構。其 機構(Structure)通過空格來展示,序列(Sequence)裏的項目“-”來代表,Map裏的鍵值對用“:”分割。

d.playbook的核心元素(http://www.ansible.com.cn/)中文網
hosts 執行的遠程主機列表
tasks 任務集
varniables 內置變量或自定義變量在playbook中調用
templates 模板,可替換模板文件中的變量並實現一些簡單邏輯文件
hanslers 和notity結合使用,有特定條件出發操作,滿足條件方可執行,否則不執行
tags 標籤 指定某條任務執行,用於選擇運行playbook中部分代碼。ansible具有冪等性,因此會自動化跳過沒有變化的部分,即便如此,有些代碼爲此時其確實沒有發生變化的時間依然會非常的長。此時,確信其沒有變化,就可以通過tags跳過此些代碼片段。

e.playbook基礎組件

hosts:
playbook中的每一個play的目的都是爲了讓某個或某些主機以某個指定的用戶身份執行任務。hosts用於指定要執行指定任務的主機,須事先定義在主機清單中

可以是如下形式:
one.example.com
one.example.com:two.example.com
192.168.1.50
192.168.1.*
webserver:dbserver 兩個組的並集
webserver:&dbserver 兩個組的交集
webserver:!dbserver 在webserver組中  但不在dbserver組中

示例: - hosts:webserver:sbserver
在這裏插入圖片描述
remote_user:
可用於Host和task中。也可以通過制定其通過sudo的方式在遠程主機上執行任務,其可用於play全局或某任務;此外;甚至可以在sudo時使用sudo_user: root時切換到用戶。

  • hosts: web
    remote_user: root
    tasks:
    • name: test connection
      ping
      remote_user: zhangwei
      sudo: yes #默認sudo爲root
      sudo_user: wang #sudo爲wang

tasks:
任務列表
格式:
1)action: module arguments
2) module: arguments 【建議使用】
注意:shell和command模塊後面跟命令,而非key=value
某任務的狀態在運行後爲change時,可通過‘notify’通知給相應的handlers
某任務可以通過‘tags’打標籤,而後可在ansible-playbook命令上使用-t指定進行調用
示例:
tasks:

  • name: disable selinux
    command: /sbin/setenforce 0

如果命令或腳本的退出碼不爲零,可以使用如下方式替代
tasks:

  • name: run this conamnd and ignore the result
    shell : /usr/bin/sommecommand || /bin/true

或者使用ignore_errors來忽略錯誤信息:
tasks:

  • name: run this conamnd and ignore the result
    shell : /usr/bin/sommecommand
    ignore_errors: True

運行playbook方式
ansible-playbook <filename.yml> … [options]
常見選項

  • –check (-C)只檢測可能會發生的改變,但不真正執行操作

  • –list-hosts 列出運行任務的主機

  • –limit 主機列表 只針對主機列表中的主機執行

  • -v 顯示過程 -vv -vvv更詳細

示例:
ansible-playbook file.yml --check 只檢測
ansible-playbook file.yml
ansible-playbook file.yml --limit webserver
ansible-playbook file.yml --list-hosts # 查看主機
ansible-playbook file.yml --list-tasks #查看任務列表
ansible-playbook file.yml --list-tags # 查看標籤

在這裏插入圖片描述
在這裏插入圖片描述
f.handlers和notify結合使用觸發條件

handlers
是tasks列表,這些task與前述的task並沒有本質上的不同,用於當關注的資源發生變化時,纔會採取一定的操作

notify 此action可用於在每個play的最後被出發,這樣可以避免多次有改變發生時,每次都執行指定的操作,僅在所有的變化發生完後一次性執行指定的操作。在notify中列出的操作稱爲handler,也即notify中調用handler中定義的操作

---
- hosts: all
  remote_user: root

  tasks:
    - name: install Apache
      yum: name=httpd state=installed
    - name: copy conf
      copy: src=/etc/httpd/conf/httpd.conf dest=/etc/httpd/conf/ backup=yes
      notify: service restart
    - name: service Apache
      service: name=httpd state=started enabled=yes

  handlers:
    - name: service restart
      service: name=httpd state=restarted

在這裏插入圖片描述
g.playbook中tags的使用
在這裏插入圖片描述ansible-playbook -t conf httpd.yml 【使用-t 指定標籤名字】
ansible-playbook -t conf,service httpd.yml
ansible-playbook httpd.yml --list-tsgs #查看標籤列表
注意:tags標籤命名可以相同,不通模塊下寫入相同tags標籤,執行時,打入標籤的模塊會同時執行

h.playbook中變量的使用
變量來源:

(1)ansible setup facts 遠程主機的所有變量都可以直接調用
eg:ansible all -m setup #查看遠程主機的所有變量
        ansible all -m setup -a 'filter=ansible_hostname'#過濾主機中的變量
        ansible all -m setup -a 'filter=ansible_hostname' ##過濾主機的主機全名 
這裏查找到的變量可以直接在playbook中調用

(2)在/etc/ansible/hosts中定義
 普通變量:主機組中主機單獨定義,優先級高與公共變量
公共組變量:針對主機組中所有主機定義統一變量

在這裏插入圖片描述
普通變量的優先級高於公共變量
在這裏插入圖片描述
(3)通過命令行指定變量,優先級最高
ansible-playbook -e varname=value
eg:

---
- hosts: web
  remote_user: root

  tasks:
    - name: install pkname
      yum: name={{ pkname }}
    - name: start serivece
      service: name={{ pkname }} state=started enabled=yes
ansible-playbook -e 'pkname=httpd'    test.yml

(4)在playbook中定義
vars:
- var1: value1
- var2: value2
在這裏插入圖片描述

ansible-playbook  test.yml

(5)在role中定義
(6)使用變量文件
可以單獨頂一個文件存放變量值
eg:

[root@192-168-10-22 ansible]# cat vars.yml 
var1: vsftpd  #注意空格
var2: httpd  #注意空格
[root@192-168-10-22 ansible]# cat test.yml 
---
- hosts: web
  remote_user: root
  vars_files:    #注意是var_files。“s”
    - vars.yml 

  tasks:
    - name: install package
      yum: name={{ var1 }}

    - name: create file
      file: name=/data/{{ var2 }}.log state=touch

變量的優先級:命令行中的-e > playbook中定義的變量 > 主機清單中定義的變量

9、模板templates

文本文件,嵌套有腳本(使用模板編程語言編寫)
jinja2語言,使用字面量,有下面形式:
字符串:使用單引號或者雙引號
數字:整數,浮點數
列表:[item1,itme2,…]
元組:(item1,itme2,…)
字典:{key1:value1,key2:value2,…}
布爾型:true/false
算術運算:+,-,*,/,//,%,**
比較操作:==,!=,>,>=,<,<=
邏輯運算:and,or,not
流表達式:For If When(循環語句)
小記:在模板目錄template下寫入模板文件,文件中可以直接調用setup變量(src可以直接書寫模板目錄下的文件)

10、when

條件測試:如果需要根據變量,facts或此前任務的執行結果來作爲某task執行與否的前提時要用到條件測試,通過when語句實現,在task中使用,jinja2的語法格式
when語句
在task後添加when子句即可使用戶條件測試;when語句支持jinji2表達式語法
示例:

  • name: ‘shutdown redhad flavored systems’
    command: /sbin/shutdown -h now
    when: ansible_os_family == “RedHat”

11、迭代:with_items

迭代:當有需要重複執行的任務時,可以使用迭代機制
對迭代項的引用,固定變量名爲“iftem”
要在task中使用with_items給定要迭代的元素列表
列表格式:

  • 字符串
  • 字典
    在這裏插入圖片描述

12、迭代嵌套子變量

在這裏插入圖片描述

13、playbook中template模板對於for if 循環的使用

在這裏插入圖片描述

for:
yml文件

- hosts: web server
  remote_user: root
  vars:
    ports:
      - listen_port: 84
      - listen_port: 85
      - listen_port: 86

  tasks:
    - name: copy conf
      template: src=for1.conf.j2 dest=/data/for1.conf

模板文件:

{% for port in ports %}   #port自定義變量
server{
        listen {{ port.listen_port }}
}
{% endfor %}

yml文件

- hosts: web
  remote_user: root
  vars:
    ports:
      - web1:
        port: 81
        name: web1.magedu.com
        rootdir: /data/website1
      - web2:
        port: 82
        name: web2.magedu.com
        rootdir: /data/website2

  tasks:
    - name: copy conf
      template: src=for2.conf.j2 dest=/data/for2.conf

模板文件:

{% for p in ports %}    #p自定義變量
server{
        listen {{ p.port }}
        servername {{ p.name }}
        documentroot {{ p.rootdir }}
}
{% endfor %}

if:
yml文件

- hosts: web
  remote_user: root
  vars:
    ports:
      - web1:
        port: 81
        name: web1.magedu.com
        rootdir: /data/website1
      - web2:
        port: 82
        #name: web2.magedu.com
        rootdir: /data/website2

  tasks:
    - name: copy conf
      template: src=if.conf.j2 dest=/data/if.conf

模板文件:

{% for p in ports %}
server{
        listen {{ p.port }}
{% if p.name is defined %} #如果p.name被定義就執行下面的servername,否則不執行
        servername {{ p.name }}
{% endif %}
        documentroot {{ p.rootdir }}
}
{% endfor %}

在這裏插入圖片描述

六、roles

ansible自1.2版本引入的新特性,用於層次性,結構化地組織playbook。roles能夠根據層次結構自動裝載變量文件、tasks以及handlers等。要使用roles只需要在playbook中使用include指令即可。簡單來講,roles就是通過分別將變量、文件、任務、模板及處理器放置於單獨的目錄中,並可以便捷地include它們的一種機制。角色一般用於主機構建服務的場景中,但也可以使用於構建守護進程等場景中

複雜場景:建議使用roles,代碼複用度高

  • 變更指定主機或主機組
  • 如命令不規範,維護和傳承成本大
  • 某些功能需要多個playbook,通過includes可以實現

在這裏插入圖片描述
roles目錄結構

playbook.yml
roles
project/
tasks/
files/
vars/  不常用
defaults/  不常用
templates/
handlers/
meta/  不常用

roles各目錄的作用

/roles/project/:項目名稱,有以下目錄
files/:存放由copy模塊或scripts模塊等調用的文件
template/:template模塊	查找所需要模板文件的目錄
tasks/:定義tasks,roles的基本元素,至少應該包含一個名爲main.yml的文件;其他的文件需要在此文件中通過include進行調用
handlers/:至少應該包含一個名爲main.yml的文件;其他的文件需要在此文件中通過include進行調用
vars/:定義變量,至少應該包含一個名爲main.yml的文件;其他的文件需要在此文件中通過include進行調用
meta/:定義當前角色的特殊設定及其依賴關係,至少應該包含一個名爲main.yml的文件;其他的文件需要在此文件中通過include進行調用
default/:設定默認變量時使用此目錄中的main.yml文件
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章