• Roles简介
    Ansible为了层次化、结构化地组织Playbook,使用了角色(roles)。Roles能够根据层次型结构自动装载变量文件、task以及handlers等。简单来讲,roles就是通过分别将变量、文件、任务、模块及处理器放置于单独的目录中,并可以便捷地include它们,roles一般用于基于主机构建服务的场景中,但也可以用于构建守护进程等场景中。

  • 创建Roles
    创建roles时一般需要以下步骤:首先创建以roles命名的目录。然后在roles目标下分别创建以个角色名称命令的目录,如websevers等,在每个角色命令的目录中分别创建files、handlers、tasks、templates、meta、defaults和vars目录,用不到的目录可以创建为空目录。最后在Playbook文件中调用各角色进行使用

  • 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文件,用于定义此角色的特殊设定及其依赖关系。

  • 案例:使用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
  • 编写httpd模块
  • 安装httpd服务
  • 修改httpd.conf配置文件

    # vim /etc/ansible/roles/httpd/tasks/main.yml
        - name: ensure apache is at the latest version 
          yum: pkg={{ servicenames}} state=latest
          template: src=/etc/ansible/templates/httpd.conf.j2 dest=/etc/httpd/conf/httpd.conf
        - name: restart httpd server
          service: name=httpd enabled=true state=restarted
  • 定义变量

    # vim /etc/ansible/roles/httpd/vars/main.yml
    # servicenames: httpd
  • 编写mysql模块
  • 并且定义变量

    # vi /etc/ansible/roles/mysql/tasks/main.yml
    - name: ensure mysql is at the latest version 
      yum: pkg={{ servicenames}} state=latest
    
    # vi /etc/ansible/roles/mysql/vars/main.yml
    servicenames: mariadb*
  • 编写php模块
  • 并且定义变量

    # vi /etc/ansible/roles/php/tasks/main.yml
    - name: ensure php is at the latest version
      yum: pkg={{ servicenames}} state=latest
    
    # vi /etc/ansible/roles/php/vars/main.yml
    servicenames: php
  • 修改httpd配置文件模板
  • 监听IP 和域名 设为变量 方便其他主机使用这个模块

详解Ansible(Roles)自动化部署配置LAMP架构详解Ansible(Roles)自动化部署配置LAMP架构详解Ansible(Roles)自动化部署配置LAMP架构详解Ansible(Roles)自动化部署配置LAMP架构

  • 在/etc/ansible/hosts文件中设置变量
    详解Ansible(Roles)自动化部署配置LAMP架构

  • 创建Playbook文件调用上面各角色安装LAMP

    [root@rabbitmq01 ansible# vim /etc/ansible/site.yml
    ---
    - hosts: abc
        remote_user: root
        roles:
         - httpd
         - mysql
         - php
    
    [root@rabbitmq01 ansible]# ansible-playbook site.yml --syntax-check  //检测语法
    
    playbook: site.yml
    [root@rabbitmq01 ansible]# ansible-playbook site.yml    //执行剧本

    详解Ansible(Roles)自动化部署配置LAMP架构

  • 测试验证
  • 去192.168.200.129主机上写一个PHP测试页面

    # echo "<?php phpinfo();?>" > /var/www/html/index.php
    # systemctl restart httpd
  • 打开浏览器输入192.168.200.129/index.php

详解Ansible(Roles)自动化部署配置LAMP架构