1. 程式人生 > >Ansible劇本介紹及使用演示(三)--技術流ken

Ansible劇本介紹及使用演示(三)--技術流ken

 

Ansible劇本編寫說明

 

一. 縮排

    yaml 的縮排要求比較嚴格。一定不能使用tab鍵

    注意:編寫yaml檔案,就忘掉shell的tab吧。

 

二. 冒號

每個冒號後面一定要有一個空格

注意:1. 以冒號結尾不需要空格

           2.表示檔案路徑的模版可以不需要空格

 

三. 短橫線  -

    想要表示列表項,使用一個短橫槓加一個空格。多個項使用同樣的縮排級別作為同一個列表的一部分

總之:

1. 嚴格控制空格編寫劇本的時候

2.劇本編寫不支援tab

 

Ansible書寫規範

 

一. 注意點

1、指令碼名:***.yml   【不是.yml也行】

2、註釋:  “#”

3、tasks: (後不能加任何字元-可以加註釋#)

4、- name: 一個 - name: 下不能有兩條功能(行)

5.每個-和:即冒號之後要有一個空格,task除外。

 

二.  劇本格式

---                     ### 劇本的開頭,可以不寫

- hosts: all         <- 處理所有伺服器,找到所有伺服器;  -(空格)hosts:(空格)all

  tasks:            <- 劇本所要乾的事情;  (空格)(空格)task:

   - command:     (空格)(空格)空格)(空格)-(空格)模組名稱:(空格)模組中對應的功能

測試劇本命令後面可以跟多個-v進行除錯檢查

 

Ansible劇本常用命令

 

1 .對劇本語法檢測

ansible-playbook --syntax-check  /root/ansible/httpd.yaml

 

2.-C模擬執行劇本

ansible-playbook  -C /root/ansible/httpd.yaml

 

3.執行劇本

ansible-playbook   /root/ansible/httpd.yaml

 

Ansible劇本例項

 

例項一:安裝httpd並啟動

第一步: 編寫一個httpdin.yaml劇本,劇本內容如下

[[email protected] ~]# vim httpdin.yaml
- hosts: all
  tasks:
   - name: install httpd
     yum: name=httpd state=present
   - name: start httpd
     service: name=httpd state=started

 

第二步:語法檢測

檢測沒有問題

[[email protected] ~]# ansible-playbook --syntax-check httpdin.yaml 

playbook: httpdin.yaml

 

第三步:模擬執行劇本

[[email protected] ~]# ansible-playbook -C httpdin.yaml 

PLAY [all] *********************************************************************************************************************

TASK [Gathering Facts] *********************************************************************************************************
ok: [10.220.5.139]
ok: [10.220.5.138]

TASK [install httpd] ***********************************************************************************************************
ok: [10.220.5.138]
changed: [10.220.5.139]

TASK [start httpd] *************************************************************************************************************
changed: [10.220.5.139]
ok: [10.220.5.138]

PLAY RECAP *********************************************************************************************************************
10.220.5.138               : ok=3    changed=0    unreachable=0    failed=0   
10.220.5.139               : ok=3    changed=2    unreachable=0    failed=0   

第四步:執行劇本

經過上面的模擬執行,並不會真的執行指令碼,下面我們來進行真正的執行

[[email protected] ~]# ansible-playbook  httpdin.yaml 

PLAY [all] *********************************************************************************************************************

TASK [Gathering Facts] *********************************************************************************************************
ok: [10.220.5.138]
ok: [10.220.5.139]

TASK [install httpd] ***********************************************************************************************************
ok: [10.220.5.138]
changed: [10.220.5.139]

TASK [start httpd] *************************************************************************************************************
ok: [10.220.5.138]
changed: [10.220.5.139]

PLAY RECAP *********************************************************************************************************************
10.220.5.138               : ok=3    changed=0    unreachable=0    failed=0   
10.220.5.139               : ok=3    changed=2    unreachable=0    failed=0   

 

第五步:檢查是否已經安裝並啟動成功

執行表名httpd安裝並啟動成功

[[email protected] ~]# ansible all -m shell -a "ss -tnl | grep 80"
10.220.5.139 | SUCCESS | rc=0 >>
LISTEN     0      128         :::80                      :::*                  

10.220.5.138 | SUCCESS | rc=0 >>
LISTEN     0      128         :::80                      :::*                  

經過上面的五步,就可以安裝任意軟體及啟動了,前提是你需要配置好你的yum源。你來試一下安裝nginx吧!

 

例項二:使用處理器

在上面的例項中,我們已經可以安裝軟體了。現在有這樣一個需求,如果我們更改了節點的配置檔案需要重啟操作,其餘動作照常執行怎麼解決?

第一步:本地準備一個httpd配置檔案,更改埠號為8081

[[email protected] ~]# cp /etc/httpd/conf/httpd.conf ./
[[email protected] ~]# sed -i "s/Listen 80/Listen 8081/" httpd.conf 

 

第二步:編寫劇本

劇本說明:

- hosts: all 指定主機組,可以理解為這個最大,頂個寫

  tasks:       指定下面一系列的動作,這個是第二,需要有兩個空格

    - name: 指定名稱,排行第三,需要有三到四個空格

      yum: 模組名 排行第四,需要有四到五個空格

  headlers:指定處理器(觸發器),排行第二,需要與tasks對齊

- hosts: all
  tasks:
   - name: install httpd
      yum: name=httpd state=present
   - name: copy file
     copy: src=/root/httpd.conf dest=/etc/httpd/conf/httpd.conf
     notify:
       - restart httpd
   - name: start httpd
     service: name=httpd state=present
  handlers:
   - name: restart httpd
     service: name=httpd state=restarted

 

第三步:劇本語法檢測

劇本加測報一下錯誤,說明排版有問題

[[email protected] ~]# ansible-playbook --syntax-check httpdhe.yaml 
ERROR! Syntax Error while loading YAML.
  mapping values are not allowed in this context

The error appears to have been in '/root/httpdhe.yaml': line 4, column 11, but may
be elsewhere in the file depending on the exact syntax problem.

The offending line appears to be:

  - name: install httpd
       yum: name=httpd state=present
          ^ here

 

 第四步:排查錯誤

可以發現第四行yum多縮進了一個空格,一定要嚴格控制縮排。

tasks和hosts首字母對齊

模組和name對齊首字母

- hosts: all
  tasks:
   - name: install httpd
     yum: name=httpd state=present
   - name: copy file
     copy: src=/root/httpd.conf dest=/etc/httpd/conf/httpd.conf
     notify:
       - restart httpd
   - name: start httpd
     service: name=httpd state=present
  handlers:
   - name: restart httpd
     service: name=httpd state=restarted

 

第五步:執行劇本

注意看執行過程,中間有一步RUNNING HANDLER,說明已經出發了處理器進行了重啟操作

[[email protected] ~]# ansible-playbook httpdhe.yaml 

PLAY [all] *********************************************************************************************************************

TASK [Gathering Facts] *********************************************************************************************************
ok: [10.220.5.139]
ok: [10.220.5.138]

TASK [install httpd] ***********************************************************************************************************
ok: [10.220.5.139]
ok: [10.220.5.138]

TASK [copy file] ***************************************************************************************************************
changed: [10.220.5.139]
changed: [10.220.5.138]

TASK [start httpd] *************************************************************************************************************
ok: [10.220.5.138]
ok: [10.220.5.139]

RUNNING HANDLER [restart httpd] ************************************************************************************************
changed: [10.220.5.139]
changed: [10.220.5.138]

PLAY RECAP *********************************************************************************************************************
10.220.5.138               : ok=5    changed=2    unreachable=0    failed=0   
10.220.5.139               : ok=5    changed=2    unreachable=0    failed=0   

 

第六步:檢查埠

上面我們已經把配置檔案的埠改成8081了,檢查下節點啟動的是否是8081

可以發現節點中的8081已經啟動

[[email protected] ~]# ansible all -m shell -a "ss -tnl | grep 8081" 
10.220.5.139 | SUCCESS | rc=0 >>
LISTEN     0      128         :::8081                    :::*                  

10.220.5.138 | SUCCESS | rc=0 >>
LISTEN     0      128         :::8081                    :::*                  

 

例項三:劇本中使用判斷

劇本中可以使用when來進行判斷

現在我們再主機名為ken1的節點之上建立一個使用者tang

第一步:域名解析

確保本機以及節點之上可以解析IP和域名

[email protected] ~]# echo "10.220.5.138 ken1" >>/etc/hosts

 

第二步:編寫劇本

ansible_fqdn是一個變數,可以用如下命令看到,表示的是主機名

[[email protected] ~]# ansible 10.220.5.138 -m setup | grep ansible_fqdn
        "ansible_fqdn": "ken1", 

在編寫劇本的時候ken1即主機名需要加上雙引號或者單引號,否則會報錯

- hosts: all
  tasks:
   - name: useradd tang
     user: name=tang uid=566 system=yes
     when: ansible_fqdn ==  "ken1"

 

第三步:語法檢測

[[email protected] ~]# ansible-playbook --syntax-check useradd.yaml 

playbook: useradd.yaml

 

第四步:執行劇本

可以看到10.220.5.139跳過了

[[email protected] ~]# ansible-playbook useradd.yaml 

PLAY [all] *********************************************************************************************************************

TASK [Gathering Facts] *********************************************************************************************************
ok: [10.220.5.139]
ok: [10.220.5.138]

TASK [useradd tang] ************************************************************************************************************
skipping: [10.220.5.139]
changed: [10.220.5.138]

PLAY RECAP *********************************************************************************************************************
10.220.5.138               : ok=2    changed=1    unreachable=0    failed=0   
10.220.5.139               : ok=1    changed=0    unreachable=0    failed=0   

[[email protected] ~]# vim useradd.yaml

 

第五步:檢測是否執行成功

可以發現在主機10.220.5.138上面已經有了使用者tang

[[email protected] ~]# ansible all -m shell -a "id tang"
10.220.5.139 | FAILED | rc=1 >>
id: tang: no such usernon-zero return code

10.220.5.138 | SUCCESS | rc=0 >>
uid=566(tang) gid=566(tang) groups=566(tang)

 

例項四:劇本中使用迴圈

劇本中的迴圈使用with_items,使用item引用變數

變數的引用格式是 {{ 變數 }}

第一步:建立劇本

- hosts: all
  tasks:
    - name: useradd ding
      user: name="ding{{item}}"
      with_items:
        - a1
        - a2
        - a3
        - a4

 

第二步:語法檢測

[[email protected] ~]# ansible-playbook --syntax-check user.yaml 

playbook: user.yaml

 

第三步:執行劇本

[[email protected] ~]# ansible-playbook user.yaml

PLAY [all] *********************************************************************************************************************

TASK [Gathering Facts] *********************************************************************************************************
ok: [10.220.5.139]
ok: [10.220.5.138]

TASK [useradd ding] ************************************************************************************************************
changed: [10.220.5.138] => (item=a1)
changed: [10.220.5.139] => (item=a1)
changed: [10.220.5.138] => (item=a2)
changed: [10.220.5.139] => (item=a2)
changed: [10.220.5.138] => (item=a3)
changed: [10.220.5.139] => (item=a3)
changed: [10.220.5.138] => (item=a4)
changed: [10.220.5.139] => (item=a4)

PLAY RECAP *********************************************************************************************************************
10.220.5.138               : ok=2    changed=1    unreachable=0    failed=0   
10.220.5.139               : ok=2    changed=1    unreachable=0    failed=0   

 

第四步:檢視執行結果

可以發現使用者已經建立完畢

[[email protected] ~]# ansible all -m shell -a "tail -5 /etc/passwd"
10.220.5.139 | SUCCESS | rc=0 >>
wukong:x:1002:234::/home/wukong:/bin/bash
dinga1:x:1003:1003::/home/dinga1:/bin/bash
dinga2:x:1004:1004::/home/dinga2:/bin/bash
dinga3:x:1005:1005::/home/dinga3:/bin/bash
dinga4:x:1006:1006::/home/dinga4:/bin/bash

10.220.5.138 | SUCCESS | rc=0 >>
tang:x:566:566::/home/tang:/bin/bash
dinga1:x:1002:1002::/home/dinga1:/bin/bash
dinga2:x:1003:1003::/home/dinga2:/bin/bash
dinga3:x:1004:1004::/home/dinga3:/bin/bash
dinga4:x:1005:1005::/home/dinga4:/bin/bash

 

自我感覺這個迴圈很low,如果建立1000個使用者難道需要這樣寫- a1 -a2 -a3...-a1000個嗎?

 

例項五:劇本中使用變數

自定義變數的實現方式

1. 直接寫在yaml檔案中

2. 在Inventory file中定義

3. 變數的宣告:

vars:

 - 變數名: 變數值

4. 變數的引用:{{ var }}

5. vars和tasks同級,並要寫在tasks前面

 

下面的劇本定義了一個變名為pkgname 變數值為mariadb-server, 變數名為sername,變數值為mariadb兩個變數

第一步:建立劇本

- hosts: all
  vars:
    - pkgname: mariadb-server
    - sername: mariadb
  tasks:
    - name: install mariadb
      yum: name={{ pkgname }} state=present
    - name: start mariadb
      service: name={{ sername }} state=started

 

第二步:語法檢測

[[email protected] ~]# ansible-playbook --syntax-check mariadb.yaml 

playbook: mariadb.yaml

 

第三步:執行劇本

[[email protected] ~]# ansible-playbook mariadb.yaml 

PLAY [all] *********************************************************************************************************************

TASK [Gathering Facts] *********************************************************************************************************
ok: [10.220.5.139]
ok: [10.220.5.138]

TASK [install mariadb] *********************************************************************************************************
ok: [10.220.5.138]
ok: [10.220.5.139]

TASK [start mariadb] ***********************************************************************************************************
changed: [10.220.5.138]
changed: [10.220.5.139]

PLAY RECAP *********************************************************************************************************************
10.220.5.138               : ok=3    changed=1    unreachable=0    failed=0   
10.220.5.139               : ok=3    changed=1    unreachable=0    failed=0   

 

第四步:檢測劇本是否執行成功

[[email protected] ~]# ansible all -m shell -a "ss -tnl| grep 3306"
10.220.5.139 | SUCCESS | rc=0 >>
LISTEN     0      50           *:3306                     *:*                  

10.220.5.138 | SUCCESS | rc=0 >>
LISTEN     0      50           *:3306                     *:*