自动化运维-ansible中对roles的创建与使用

发布于:2025-09-06 ⋅ 阅读:(17) ⋅ 点赞:(0)

自动化运维-ansible中对roles的创建与使用

一、Ansible 角色概述

角色的作用

随着 Playbook 复杂度增加,代码重复利用变得困难。Ansible 角色提供了一种标准化方式打包任务、变量、文件和模板,使得代码可以轻松地在不同项目间共享和重用。

角色的核心优势
  1. 模块化设计:将相关功能组织成独立单元
  2. 代码复用:轻松在不同项目间共享配置
  3. 协作开发:多个管理员可并行开发不同角色
  4. 易于维护:大型项目通过角色分解更易管理
  5. 社区支持:可从 Ansible Galaxy 获取社区贡献的角色

二、各目录作用说明

  1. defaults/main.yml - 定义默认变量,优先级最低,适合设置可覆盖的默认值
  2. vars/main.yml - 定义角色内部变量,优先级高,通常不应在playbook中修改
  3. tasks/main.yml - 包含角色的主要任务序列
  4. handlers/main.yml - 定义角色使用的处理器
  5. files/ - 存放静态文件,任务中可直接引用文件名
  6. templates/ - 存放Jinja2模板,任务中可直接引用模板名
  7. meta/main.yml - 包含角色作者、许可证、平台要求和依赖关系
  8. tests/ - 包含测试角色用的清单和playbook

三、执行顺序控制

Playbook 中任务执行顺序

  1. pre_tasks - 在角色之前执行
  2. roles - 按顺序执行角色任务
  3. tasks - 普通任务
  4. post_tasks - 在角色和普通任务后执行
  5. handlers - 被触发的处理器,最后执行

四、动态角色包含

除了静态角色定义,还可以在任务中动态包含角色

  • include_role:动态包含,在执行时处理
  • import_role:静态导入,在解析时处理

五、创建与使用角色

  1. 创建角色

    [student@master ansible]$ cd roles/
    [student@master roles]$ ansible-galaxy init testuser
    [student@master roles]$ ls testuser/
    

    在这里插入图片描述

  2. 给角色定义变量

    [student@master roles]$ cd testuser/
    [student@master testuser]$ vim vars/main.yml 
    # playbook内容如下
    ---
    a: 1
    b: 2
    c: 3
    
  3. 给角色写任务

    [student@master testuser]$ vim tasks/main.yml
    # 内容如下
    ---
    - name: test1
      debug:
        msg: "{{a}}"
          
    - name: test2
      debug:
        msg: "{{b}}"
          
    - name: test3
      debug:
        var: c
    
  4. 创建一个 playbook 来使用角色

    [student@master ansible]$ vim testuser.yml
    # playbook内容如下
    ---
    - name: testu
      hosts: node1
      roles:
        - testuser
    

    在这里插入图片描述

六、创建与使用角色示例

需求

在/etc/ansible/roles中创建名为http的角色

1、部署yum仓库

2、安装httpd软件包

3、模板文件index.html.j2已存在,用户创建具有以下输出的文件/var/www/html/index.html:

Welcome to HOSTNAME on IPADDRESS

当index.html内容发生改变时,重启httpd服务

其中HOSTNAME是受控节点的完全合格域名,IPADDRESS则是受控节点的IP地址

按照上方所述,创建一个使用此角色的playbook /etc/ansible/newrole.yml,该playbook在所有主机上运行

yum 仓库已经部署完成

  1. 创建 http 角色

    [student@master ansible]$ cd roles/
    [student@master roles]$ ansible-galaxy init http
    
  2. 新建 index.html.j2 模板

    [student@master http]$ vim templates/index.html.j2
    # 编辑内容如下
    Welcome to {{ansible_fqdn}} on {{ansible_default_ipv4.address}}
    
  3. 给角色写任务

    [student@master http]$ vim tasks/main.yml
    # 内容如下
    ---
    # tasks file for http
    - name: install httpd firewalld
      yum:
        name:
          - httpd
          - firewalld
        state: present
    
    - name: cp file
      template:
        src: index.html.j2
        dest: //var/www/html/index.html
    
    - name: restarted
      service:
        name: "{{item}}"
        state: restarted
        enable: yes
      loop:
        - httpd
        - firewalld
    
    - name: set firewalld
      firewalld:
        service: http
        state: enabled
        permanent: yes
        immediate: yes
    
  4. 创建一个 playbook 来使用角色

    [student@master ansible]$ vim httpuser.yml
    # 内容如下
    ---
    - name: web
      hosts: all
      roles:
        - http
    

    在这里插入图片描述

七、系统角色

  1. 安装系统角色

    [student@master ansible]$ sudo yum -y install rhel-system-roles
    

    在这里插入图片描述

  2. 将时钟同步的系统角色复制到/etc/ansible/roles目录下,并重名了角色名为timesync

    [student@master ansible]$ cp -r /usr/share/ansible/roles/rhel-system-roles.timesync -p roles/timesync
    
  3. 书写playbook,并执行

    [student@master ansible]$ vim timesync.yml
    # 内容如下
    ---
    - name: chrony
      hosts: test01
      vars:
        timesync_ntp_servers:
          - hostname: ansible.example.com
            iburst: yes
      roles:
        - timesync
    

    在这里插入图片描述


网站公告

今日签到

点亮在社区的每一天
去签到