Ansibel之roles的使用

Ansibel之roles的使用

roles介绍

roles可以根据层次型结构自动装载变量文件、task以及handlers等。简单来说,roles就是经过分别将变量、文件、任务、模块及处理器放置于单独的目录中,并能够便捷地include它们,roles通常用于基于主机构建服务的场景中,但也能够用于构建守护进程等场景中。php

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

    搭建LAMP架构

    建立各个模版所须要的文件夹

    [root@rabbitmq01 roles]# mkdir /etc/ansible/roles/httpd/{files,templates,tasks,handlers,valts,meta} -p
    #建立httpd服务所须要的目录
    [root@rabbitmq01 roles]# ls
    httpd
    [root@rabbitmq01 roles]# cd httpd/
    [root@rabbitmq01 httpd]# ls
    defaults  files  handlers  meta  tasks  templates  vars

[root@rabbitmq01 httpd]# mkdir /etc/ansible/roles/mysql/{files,templates,tasks,handlers,vars,defaults,meta} -p
#建立mysql服务所须要的目录mysql

[root@rabbitmq01 httpd]# mkdir /etc/ansible/roles/php/{files,templates,tasks,handlers,vars,defaults,meta} -p
#建立php服务所须要的目录web

#### 建立main.yml文件

[root@rabbitmq01 httpd]# touch /etc/ansible/roles/httpd/{defaults,vars,tasks,meta,handlers}/main.yml
[root@rabbitmq01 httpd]# touch /etc/ansible/roles/mysql/{defaults,vars,tasks,meta,handlers}/main.yml
[root@rabbitmq01 httpd]# touch /etc/ansible/roles/php/{defaults,vars,tasks,meta,handlers}/main.ymlsql

#### 编写httpd服务模块

[root@rabbitmq01 httpd]# vim tasks/main.yml apache

  • name: ensure apache is at the latest version
    yum: pkg={{ pkg }} state=latest

[root@rabbitmq01 httpd]# vim /etc/ansible/roles/httpd/vars/main.yml
[root@rabbitmq01 httpd]# cat /etc/ansible/roles/httpd/vars/main.yml
pkg: httpd
#定义变量:能够定义在全局变量中,也能够定义在roles角色变量中,通常定义在角色变量中vim

#### 编写mysql服务模块

[root@rabbitmq01 httpd]# vim /etc/ansible/roles/mysql/tasks/main.yml
[root@rabbitmq01 httpd]# cat /etc/ansible/roles/mysql/tasks/main.yml centos

  • name: ensure mysql is at the latest version
    yum: pkg={{ pkg }} state=latest

[root@rabbitmq01 httpd]# vim /etc/ansible/roles/mysql/vars/main.yml
[root@rabbitmq01 httpd]# cat /etc/ansible/roles/mysql/vars/main.yml
pkg: mariadb*架构

#### 编写php服务模块

[root@rabbitmq01 httpd]# vim /etc/ansible/roles/php/tasks/main.yml
[root@rabbitmq01 httpd]# cat /etc/ansible/roles/php/tasks/main.ymlssh

  • name: ensure php is at the latest version
    yum: pkg={{ pkg }} state=latest

[root@rabbitmq01 httpd]# vim /etc/ansible/roles/php/vars/main.yml
[root@rabbitmq01 httpd]# cat /etc/ansible/roles/php/vars/main.yml
pkg: phpide

#### 编写role文件

[root@rabbitmq01 httpd]# vim /etc/ansible/site.yml
[root@rabbitmq01 httpd]# cat /etc/ansible/site.yml

  • hosts: webserver
    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

PLAY [webserver] ****

TASK [Gathering Facts] **
Enter passphrase for key '/root/.ssh/id_rsa':
ok: [192.168.58.132]

TASK [httpd : ensure apache is at the latest version] ***
ok: [192.168.58.132]

TASK [mysql : ensure mysql is at the latest version] ****
ok: [192.168.58.132]

TASK [php : ensure php is at the latest version] ****
changed: [192.168.58.132]

PLAY RECAP **
192.168.58.132 : ok=4 changed=1 unreachable=0 failed=0

[root@rabbitmq02 ~]# rpm -q httpdhttpd-2.4.6-80.el7.centos.1.x86_64[root@rabbitmq02 ~]# rpm -q mariadbmariadb-5.5.56-2.el7.x86_64[root@rabbitmq02 ~]# rpm -q phpphp-5.4.16-45.el7.x86_64#能够看到安装成功

相关文章
相关标签/搜索