Ansible自动化运维 (Roles的编写)

本文介绍了Ansible Roles的概念和重要性,详细讲解了Roles的目录结构,并通过创建apache、haproxy和keepalived roles的示例,展示了如何组织和编写Roles。Roles有助于在企业环境中实现服务配置的模块化和复用,提高运维效率。
摘要由CSDN通过智能技术生成

1. Roles介绍

  • Ansible roles是为了层次化、结构化地组织Playbook。
  • roles就是通过分别将变量、文件、任务、模块及处理器放置于单独的目录中,并可以便捷地include它们。
  • roles一般用于基于主机构建服务的场景中,在企业复杂业务场景中应用的频率很高。以特定的层级目录结构进行组织的tasks、variables、handlers、templates、files等;相当于函数的调用把各个功能切割成片段来执行。
  • 应用场景:
  • 假如我们现在有3个被管理主机,第一个要配置成httpd,第二个要配置成nginx服务器,第三个要配置成pho服务器。第一个play用到第一个主机上,用来构建httpd,第二个play用到第二个主机上,用来构建nginx,第三个play用到第三个主机上,用来构建php。这些个play定义在playbook中比较麻烦,将来也不利于模块化调用,不利于多次调用。比如说后来又加进来一个主机,这个第4个主机既是httpd服务器,又是php服务器,我们只能写第4个play,上面写上安装httpd和php。这样playbook中的代码就重复了,为了避免代码重复,roles能够实现代码重复被调用。

2. Roles的目录结构

  • role_name:定义的role名字
  • files:存放copy或script等模块调用的函数
  • tasks:定义各种task,要有main.yml,其他文件include包含调用
  • handlers:定义各种handlers,要有main.yml,其他文件include包含调用
  • vars:定义variables,要有main.yml,其他文件include包含调用
  • templates:存储由template模块调用的模板文本
  • meta:定义当前角色的特殊设定及其依赖关系,要有main.yml的文件
  • defaults:要有main.yml的文件,用于设定默认变量
  • tests: 用于测试角色

3. Roles示例

实验环境
server1 192.168.43.10 主机
server2 192.168.43.2
server3 192.168.43.3
server4 192.168.43.4

3.1. roles的存放路径

  • role存放的路径在配置文件ansible.cfg中定义:
    roles_path = path/roles (默认目录:/etc/ansible/roles)
  • vim ansible.cfg
    在这里插入图片描述

3.2 创建目录结构

$ ansible-galaxy init apache
$ ansible-galaxy list 
[devops@server1 ansible]$ cd roles/
[devops@server1 roles]$ ansible-galaxy init apache
- Role apache was created successfully
[devops@server1 roles]$ ansible-galaxy init haproxy
- Role haproxy was created successfully
[devops@server1 roles]$ ansible-galaxy init keepalived
- Role keepalived was created successfully

在这里插入图片描述

  • ansible-galaxy命令工具
  • Ansible Galaxy 是一个免费共享和下载 Ansible 角色的网站,可以帮助我们更好的定义和学习roles。
  • ansible-galaxy命令默认与https://galaxy.ansible.com网站API通信,可以查找、下载各种社区开发的 Ansible 角色。
  • ansible-galaxy在 Ansible 1.4.2 就已经被包含了。

3.3 编写apache role

vim apache/tasks/main.yml

 ---
- name: install apache
  yum:
    name:
       - httpd
       - php
    state: present

- name: copy index.html
  copy:
    content: "{
   { ansible_facts['hostname'] }}\n"
    dest: /var
  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值