Ansible---Roles簡單搭建LAMP架構案例
- roles能夠根據層次型結構自動裝載變量文件、task以及handlers等。簡單來講,roles就是通過分別將變量、文件、任務、模塊及處理器放置於單獨的目錄中,並可以便捷地include它們,roles一般用於基於主機構建服務的場景中,但也可以用於構建守護進程等場景中。
-
針對roles中各個不同執行操作需要建立單獨目錄。
- 例如:
roles/
httpd/
files/
templates/
tasks/
handlers/
vars/
defaults/
meta/
roles內各目錄含義解釋
files:用來存放由copy模塊或script模塊調用的文件。
templates:用來存放jinjia2模板,template模塊會自動在此目錄中尋找jinjia2模板文件。
tasks:此目錄應當包含一個main.yml文件,用於定義此角色的任務列表,此文件可以使用include包含其它的位於此目錄的task文件。
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.yaml
touch /etc/ansible/roles/mysql/{defaults,vars,tasks,meta,handlers}/main.yaml
6)在playbook文件中,調用各角色。
vim /etc/ansible/lamp.yaml
---
- hosts: webserver
remote_user: root
roles:
- httpd
- mysql
ansible-playbook lamp.yaml
利用Roles簡單安裝LAMP架構
1、創建工作目錄及對應yaml文件
- 創建roles執行目錄
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
- 創建執行目錄下yaml文件,註意每個目錄下文件名稱必須是main.yaml格式,否則無法識別.
touch /etc/ansible/roles/httpd/{defaults,vars,tasks,meta,handlers}/main.yaml
touch /etc/ansible/roles/mysql/{defaults,vars,tasks,meta,handlers}/main.yaml
touch /etc/ansible/roles/php/{defaults,vars,tasks,meta,handlers}/main.yaml
2、httpd模塊
vim /etc/ansible/roles/httpd/tasks/main.yaml
- name: ensure apache is at the latest version
yum: pkg={{ pkg }} state=latest
- 定義變量:可以定義在全局變量中,也可以定義在roles角色變量中,一般定義在角色變量中
vim/etc/ansible/roles/httpd/vars/main.yaml
pkg: httpd
3、mysql模塊
vim /etc/ansible/roles/mysql/tasks/main.yaml
- name: ensure mysql is at the latest version
yum: pkg={{ pkg }} state=latest
vim /etc/ansible/roles/mysql/vars/main.yaml
pkg: mariadb*
4、php模塊
vim /etc/ansible/roles/php/tasks/main.yaml
- name: ensure php is at the latest version
yum: pkg={{ pkg }} state=latest
vim /etc/ansible/roles/php/vars/main.yml
pkg: php
5、編寫role執行實例
vim /etc/ansible/lamp.yaml
---
- hosts: webserver //對主機組執行role
remote_user: root
roles: //依次需要執行的role
- httpd
- mysql
- php
- 按照playbook方式執行role
ansible-playbook lamp.yaml
Ansible---Roles簡單搭建LAMP架構案例