Ansible之角色扮演:roles。案例介紹:使用roles安裝LAMP環境

ansible中roles介紹

  • roles能夠根據層次型結構自動裝載變量文件、task以及handlers等。簡單來講,roles就是通過分別將變量、文件、任務、模塊及處理器放置於單獨的目錄中,並可以便捷地include它們,roles一般用於基於主機構建服務的場景中,但也可以用於構建守護進程等場景中。

roles/

   common/

     files/

     templates/

     tasks/

     handlers/

     vars/

     defaults/

     meta/

   web/

     files/

     templates/

     tasks/

     handlers/

     vars/

     defaults/

     meta/

roles內各目錄含義解釋

files:用來存放由copy模塊或script模塊調用的文件。


templates:用來存放jinjia2模板,template模塊會自動在此目錄中尋找jinjia2模板文件。


tasks:此目錄應當包含一個main.yml文件,用於定義此角色的任務列表,此文件可以使用include

包含其它的位於此目錄的task文件。   mail.yml 默認執行程序


handlers:此目錄應當包含一個main.yml文件,用於定義此角色中觸發條件時執行的動作。


vars:此目錄應當包含一個main.yml文件,用於定義此角色用到的變量。


defaults:此目錄應當包含一個main.yml文件,用於爲當前角色設定默認變量。


meta:此目錄應當包含一個main.yml文件,用於定義此角色的特殊設定及其依賴關係。


在一個playbook中使用roles的步驟:


1)創建以roles命令的目錄。

mkdir /etc/ansible/roles/ -p    #yum裝完默認就有


2)創建全局變量目錄。

mkdir /etc/ansible/group_vars/ -p

touch /etc/ansible/group_vars/all     #文件名自己定義,引用的時候注意


3)在roles目錄中分別創建以各角色名稱命令的目錄,如httpd。

mkdir /etc/ansible/roles/common -p


4)在每個角色命令的目錄中分別創建files、handlers、tasks、templates、meta、defaults和vars目錄,用不到的目錄可以創建爲空目錄,但不可以不創建。

mkdir /etc/ansible/roles/httpd/{files,templates,tasks,handlers,vars,defaults,meta} -p

mkdir /etc/ansible/roles/mysql/{files,templates,tasks,handlers,vars,defaults,meta} -p


5)在每個角色的handlers、tasks、meta、defaults、vars目錄下創建main.yml文件,千萬不能自定義。

touch /etc/ansible/roles/httpd/{defaults,vars,tasks,meta,handlers}/main.yml

touch /etc/ansible/roles/mysql/{defaults,vars,tasks,meta,handlers}/main.yml


6)在playbook文件中,調用各角色。

vi /etc/ansible/site.yml

---

- hosts: webserver

  remote_user: root

  roles:

     - httpd

     - mysql


實驗案例:使用roles搭建LAMP架構

創建httpd、mysql、php角色名稱目錄,並在其目錄下創建files、handlers、tasks、templates、meta、defaults和vars目錄

mkdir /etc/ansible/roles/httpd/{files,templates,tasks,handlers,vars,defaults,meta} -p

mkdir /etc/ansible/roles/mysql/{files,templates,tasks,handlers,vars,defaults,meta} -p

mkdir /etc/ansible/roles/php/{files,templates,tasks,handlers,vars,defaults,meta} -p


touch /etc/ansible/roles/httpd/{defaults,vars,tasks,meta,handlers}/main.yml

touch /etc/ansible/roles/mysql/{defaults,vars,tasks,meta,handlers}/main.yml

touch /etc/ansible/roles/php/{defaults,vars,tasks,meta,handlers}/main.yml

50.png

------編寫httpd模塊------

寫一個簡單的tasks/main.yml

vi /etc/ansible/roles/httpd/tasks/main.yml

- name: ensure apache is at the late st version 

  yum: pkg={{ pkg }} state=latest

 

定義變量:可以定義在全局變量中,也可以定義在roles角色變量中,一般定義在角色變量中

vi /etc/ansible/roles/httpd/vars/main.yml

pkg: httpd

51.png52.png

-------編寫mysql模塊-------

vi /etc/ansible/roles/mysql/tasks/main.yml

- name: ensure mysql is at the latest version 

  yum: pkg={{ pkg }} state=latest

  

vi /etc/ansible/roles/mysql/vars/main.yml

pkg: mariadb*

53.png54.png

-------編寫php模塊-----

vi /etc/ansible/roles/php/tasks/main.yml

- name: ensure php is at the latest version

  yum: pkg={{ pkg }} state=latest


vi /etc/ansible/roles/php/vars/main.yml

pkg: php

55.png56.png

-----編寫roles示例-----

vi /etc/ansible/lamp.yml

---

- hosts: webserver

  remote_user: root

  roles:

   - httpd

   - mysql

   - php

19.png

-------執行playbook---------

ansible-playbook lamp.yml

59.png

在webserver上的httpd站點目錄下編寫php測試首頁,並通過瀏覽器進行訪問

58.png57.png


總結:

使用ansible的roles功能把緊密連接的服務全部拆開,可以降低軟件的耦合性。大大簡化軟件項目的部署實施,並且能夠方便後期維護,有利於項目的推廣使用。

解耦應用是現在的一大趨勢,利用roles能夠很好的實現這一優勢。



發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章