Ansible---Roles簡單搭建LAMP架構案例

Roles介紹

  • roles可以根據層次型結構自動裝載變量文件、task以及handlers等。簡單來說,roles就是經過分別將變量、文件、任務、模塊及處理器放置於單獨的目錄中,並能夠便捷地include它們,roles通常用於基於主機構建服務的場景中,但也能夠用於構建守護進程等場景中。
  • 針對roles中各個不一樣執行操做須要創建單獨目錄。php

  • 例如:
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文件,用於定義此角色的特殊設定及其依賴關係。mysql

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

1)建立以roles命令的目錄。web

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

2)建立全局變量目錄。apache

mkdir /etc/ansible/group_vars/ -p
touch /etc/ansible/group_vars/all #文件名本身定義,引用的時候注意vim

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

mkdir /etc/ansible/roles/common -pide

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

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

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架構

一、建立工做目錄及對應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

二、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

三、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*

四、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

五、編寫role執行實例

vim /etc/ansible/lamp.yaml

---
- hosts: webserver     //對主機組執行role
  remote_user: root
  roles:      //依次須要執行的role
   - httpd
   - mysql
   - php
  • 按照playbook方式執行role

ansible-playbook lamp.yaml

相關文章
相關標籤/搜索