自动化运维工具-Ansible的Roles的使用

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了自动化运维工具-Ansible的Roles的使用相关的知识,希望对你有一定的参考价值。


Roles的使用

  • ​​前言​​
  • ​​一、Roles是什么?​​
  • ​​二、目录层级说明​​
  • ​​三、调用Roles实例​​

前言

往期Ansible目录
​​1、自动化运维工具-Ansible实战指南​​2、自动化运维工具-Ansible的Playbook的使用
3、自动化运维工具-Ansible的Roles的使用
​4、B站学习链接​

一、Roles是什么?

  1. 编写playbook有个弊端就是无法实现复用
  2. 假设在同时部署Web、db、ha 时或不同服务器组合不同的应用就需要写多个yml文件。很难实现灵活的调用。。
  3. roles 用于层次性、结构化地组织playbook。roles能够根据层次型结构自动装载变量文件、tasks以及handlers等。
  4. 要使用roles只需要在playbook中使用include指令即可。
  5. 简单来讲,roles就是通过分别将变量(vars)、文件(file)、任务(tasks)、模块(modules)及处理器(handlers)放置于单独的目录中,并可以便捷地include它们的一种机制。
  6. 角色一般用于基于主机构建服务的场景中,但也可以是用于构建守护进程等场景中。

二、目录层级说明

roles每个角色中,以特定的层级目录进行组织

Mysql/ 角色

  • Files/ #存放有copy或script模块等调用的文件;’
  • Tepmlates/ #template模块查找所需要模板文件目录;
  • Tasks/
    #定义任务;至少应该包含一个名为main.yml的文件;其他的文件需要在此文件中通过include进行包含。
  • Handlers/
    #定义触发器;至少应该包含一个名为main.yml的文件;其他的文件需要在此文件中通过include进行包含。
  • Vars/
    #定义变量;至少应该包含一个名为main.yml的文件;其他的文件需要在此文件中通过include进行包含。
  • Meta/ #定义变量;至少应该包含一个名为main.yml的文件;定义当前角色的特殊设定及其依赖
    关系;其他的文件需要在此文件中通过include进行包含。
  • Default/ #设定默认变量时使用此目录中的main.yml文件。

三、调用Roles实例

#创建固定目录结构
[root@ansible roles]# tree
.
├── httpd
│ ├── files
│ │ └── httpd.conf
│ └── tasks
│ ├── copyfile.yml
│ ├── main.yml
│ └── user.yml
├── memcache
├── mysql
└── nginx
├── main.yml
├── tasks
│ ├── group.yml
│ ├── restart.yml
│ ├── start.yml
│ ├── user.yml
│ └── yum.yml
└── templates

8 directories, 10 files
[root@ansible roles]# cd nginx/



#定义执行的顺序
[root@ansible nginx]# cat main.yml
- include: group.yml
- include: user.yml
- include: yum.yml
- include: start.yml

#每个任务分别写出来
[root@ansible nginx]# cd tasks/
[root@ansible tasks]# cat group.yml
- name: create group
group: name=nginx gid=80
[root@ansible tasks]# cat restart.yml
- name: start service
service: name=nginx state=restarted
[root@ansible tasks]# cat start.yml
- name: start service
service: name=nginx state=started enabled=yes
[root@ansible tasks]# cat user.yml
- name: create user
user: name=nginx group=nginx uid=80 system=yes shell=/sbin/nologin
[root@ansible tasks]# cat yum.yml
- name: yum install package
yum: name=nginx



编写yml调用nginx角色
[root@ansible ansible]# cat role_nginx.yml
- hosts: wsr
remote_user: root
roles:
- role: nginx



通过ansible-playbook来执行
[root@ansible ansible]# ansible-playbook role_nginx.yml

PLAY [wsr] *****************************************************************************

TASK [Gathering Facts] *****************************************************************
ok: [192.168.100.10]
ok: [192.168.100.20]

PLAY RECAP *****************************************************************************
192.168.100.10 : ok=1 changed=0 unreachable=0 failed=0 skipped=0 rescued=0 ignored=0
192.168.100.20 : ok=1 changed=0 unreachable=0 failed=0 skipped=0 rescued=0 ignored=0

日后再更~~~


以上是关于自动化运维工具-Ansible的Roles的使用的主要内容,如果未能解决你的问题,请参考以下文章

自动化运维工具ansible 角色Roles介绍

自动化运维工具Ansible之Roles测验详解

自动化运维工具Ansible之Roles测验详解

运维自动化-Ansible roles

自动化运维Ansible之Roles部署配置LAMP架构

自动化运维工具——ansible系列命令