掌握Ansible角色(Roles)自動化部署配置LAMP架構
阿新 • • 發佈:2018-10-31
-
Roles簡介:
Ansible為了層次化、結構化地組織Playbook,使用了角色(roles)。Roles能夠根據層次型結構自動裝載變數檔案、task以及handlers等。簡單來講,roles就是通過分別將變數、檔案、任務、模組及處理器放置於單獨的目錄中,並可以便捷地include它們,roles一般用於基於主機構建服務的場景中,但也可以用於構建守護程序等場景中。
- 在一個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內各目錄含義:
* 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檔案,用於定義此角色的特殊設定及其依賴關係。
實驗專案:使用roles搭建LAMP架構
1.首先建立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
2.編寫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
3.編寫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*
4.編寫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
5.編寫roles示例:
* vi /etc/ansible/lamp.yml
--
- hosts: webserver
remote_user: root
roles:
- httpd
- mysql
- php
6.執行playbook:
7.在webserver上的httpd站點目錄下編寫php測試首頁,並通過瀏覽器進行訪問:
總結:使用ansible的roles功能把緊密連線的服務全部拆開,可以降低軟體的耦合性。大大簡化軟體專案的部署實施,並且能夠方便後期維護,有利於專案的推廣使用。