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能够很好的实现这一优势。



猜你喜欢

转载自blog.51cto.com/13728740/2309086