码迷,mamicode.com
首页 > 其他好文 > 详细

掌握Ansible角色(Roles)自动化部署配置LAMP架构

时间:2018-10-31 17:54:53      阅读:162      评论:0      收藏:0      [点我收藏+]

标签:--   ensure   不能   pac   jinjia   实验   png   process   总结   

  • 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功能把紧密连接的服务全部拆开,可以降低软件的耦合性。大大简化软件项目的部署实施,并且能够方便后期维护,有利于项目的推广使用。

    掌握Ansible角色(Roles)自动化部署配置LAMP架构

    标签:--   ensure   不能   pac   jinjia   实验   png   process   总结   

    原文地址:http://blog.51cto.com/13721050/2311280

    (0)
    (0)
       
    举报
    评论 一句话评论(0
    登录后才能评论!
    © 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
    迷上了代码!