当前位置: 首页 > ai >正文

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

自动化运维-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: test1debug:msg: "{{a}}"- name: test2debug:msg: "{{b}}"- name: test3debug:var: c
    
  4. 创建一个 playbook 来使用角色

    [student@master ansible]$ vim testuser.yml
    # playbook内容如下
    ---
    - name: testuhosts: node1roles:- 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 firewalldyum:name:- httpd- firewalldstate: present- name: cp filetemplate:src: index.html.j2dest: //var/www/html/index.html- name: restartedservice:name: "{{item}}"state: restartedenable: yesloop:- httpd- firewalld- name: set firewalldfirewalld:service: httpstate: enabledpermanent: yesimmediate: yes
    
  4. 创建一个 playbook 来使用角色

    [student@master ansible]$ vim httpuser.yml
    # 内容如下
    ---
    - name: webhosts: allroles:- 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: chronyhosts: test01vars:timesync_ntp_servers:- hostname: ansible.example.comiburst: yesroles:- timesync
    

    在这里插入图片描述

http://www.xdnf.cn/news/20028.html

相关文章:

  • 数据无言,网关有声 耐达讯自动化RS485转Profinet让千年液位数据“开口说话”
  • 在VSCode中更新或安装最新版的npx和uv工具
  • 数码视讯TR100-OTT-G1_国科GK6323_安卓9_广东联通原机修改-TTL烧录包-可救砖
  • 容器的定义及工作原理
  • 【华为Mate XTs 非凡大师】麒麟芯片回归:Mate XTs搭载麒麟9020,鸿蒙5.1体验新境界
  • Java 21 虚拟线程微服务进阶实战:2 个企业级场景源码 + 底层调度原理 + 性能调优指南
  • 艾克斯图片转换器,不只图片压缩
  • 音响皇帝BO,牵手全球第一AR眼镜雷鸟,耳机党坐不住了?
  • Kafka 内存池MemoryPool 设计
  • 海盗王64位dx9客户端修改篇之五
  • 别再手工缝合API了!开源LLMOps神器LMForge,让你像搭积木一样玩转AI智能体!
  • 《sklearn机器学习——回归指标1》
  • Linux中的fork详解
  • 好看的背景颜色 uniapp+小程序
  • vue3+ts导出PDF
  • 力扣55:跳跃游戏
  • 每周资讯 | 中国游戏市场将在2025年突破500亿美元;《恋与深空》收入突破50亿元
  • 52核心52线程,Intel下一代CPU憋了个大的
  • uni-app 项目 iOS 上架踩坑经验总结 从证书到审核的避坑指南
  • 一文从零部署vLLM+qwen0.5b(mac本地版,不可以实操GPU单元)
  • 为什么要用VR全景?5个答案告诉你
  • 用户眼中的VR自来水厂之旅
  • 【Android】Room数据库的使用
  • Linux系统TCP/IP网络参数优化
  • 在Unity中实现DTLN-AEC处理音频文件的功能
  • 【论文阅读】Security of Language Models for Code: A Systematic Literature Review
  • 深度学习篇---pytorch数据集
  • 【Python】数据可视化之核密度
  • 【RNN-LSTM-GRU】第二篇 序列模型原理深度剖析:从RNN到LSTM与GRU
  • 关于Spring的八股