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

Ansible之Playbook(五):高级用法

Playbook高级用法一、本地执行Local Action应用场景当控制节点非目标主机需要执行特定操作时使用如生成报告、处理临时文件等。OpenEuler实现方式- name: 在控制节点生成主机清单报告 hosts: all tasks: - name: 收集主机信息 setup: filter: ansible_* register: host_facts - name: 本地生成JSON报告 local_action: module: copy content: {{ host_facts | to_nice_json }} dest: /tmp/{{ inventory_hostname }}_report.json关键参数解析local_action声明本地执行模块delegate_to: localhost显式委托到控制节点可省略run_once: true防止在多个节点重复执行典型错误案例# 错误未使用local_action导致在远程节点执行 - name: 错误示例 copy: content: {{ host_facts }} dest: /tmp/report.json # 将在远程节点创建二、任务委托Delegate_to跨主机协作场景主备服务器切换时的VIP转移集中式日志服务器收集数据OpenEuler HA集群配置示例- name: 高可用集群维护 hosts: db_servers tasks: - name: 停止主数据库 systemd: name: mysqld state: stopped delegate_to: {{ primary_db }} run_once: true - name: 提升备节点为主 command: /usr/local/bin/promote_to_primary.sh delegate_to: {{ standby_db }}委托链进阶用法- name: 三级委托任务链 command: /opt/scripts/phase1.sh delegate_to: node1 - name: 第二阶段任务 command: /opt/scripts/phase2.sh delegate_to: node2 when: ansible_delegated_vars[ansible_host] node1三、任务暂停Pause人工干预场景滚动更新前的确认高危操作二次验证带超时的交互确认- name: 数据库迁移确认 pause: prompt: 确认迁移生产数据库(y/n) seconds: 300 # 5分钟超时 register: migration_confirm - name: 执行迁移 shell: /opt/db_migrate.sh when: migration_confirm.user_input|lower y自动化续接机制- name: 等待集群就绪 pause: minutes: 10 echo: false # 隐藏倒计时显示 - name: 验证集群状态 uri: url: http://{{ item }}:9200/_cluster/health return_content: yes loop: {{ es_servers }}四、滚动执行Rolling UpdateOpenEuler零宕期更新策略# inventory分组 [web_servers] web01 ansible_host192.168.1.101 web02 ansible_host192.168.1.102 web03 ansible_host192.168.1.103 # playbook配置 - name: 滚动更新Web服务 hosts: web_servers serial: 1 # 每次更新1台 order: sorted # 按主机名顺序执行 tasks: - name: 下线节点 haproxy: state: disabled host: {{ inventory_hostname }} backend: web_farm - name: 更新应用包 yum: name: webapp-* state: latest - name: 重启服务 systemd: name: webapp state: restarted - name: 上线节点 haproxy: state: enabled host: {{ inventory_hostname }} backend: web_farm动态批次控制serial: {{ batch_size }} # 通过--extra-vars传入批次数量五、只执行一次Run_once全局初始化场景- name: 创建集群共享目录 file: path: /mnt/cluster_shared state: directory mode: 0775 run_once: true - name: 分发集群配置文件 template: src: cluster.conf.j2 dest: /etc/cluster.conf run_once: true delegate_to: {{ primary_node }}与委托结合使用- name: 生成集群密钥 openssl_privatekey: path: /etc/cluster.key run_once: true delegate_to: localhost # 在控制端生成 - name: 分发密钥 copy: src: /etc/cluster.key dest: /etc/cluster.key mode: 0600六、设置环境变量OpenEuler系统级配置- name: 配置JAVA环境 block: - name: 设置全局环境变量 copy: content: | export JAVA_HOME/opt/jdk11 export PATH$JAVA_HOME/bin:$PATH dest: /etc/profile.d/java.sh - name: 应用配置 shell: source /etc/profile args: executable: /bin/bash进程级环境变量- name: 启动带环境变量的服务 systemd: name: app_service state: started environment: DB_HOST: {{ db_host }} APP_DEBUG: false临时环境设置- name: 编译安装软件 shell: make install environment: CC: /usr/bin/clang CXX: /usr/bin/clang CFLAGS: -O3 -marchnative七、交互式提示Vars_prompt密码安全处理vars_prompt: - name: db_password prompt: 请输入数据库密码 private: yes encrypt: sha512_crypt # OpenEuler支持的加密方式 confirm: yes # 二次确认输入 tasks: - name: 配置数据库密码 template: src: db_config.j2 dest: /etc/db.conf条件化交互vars_prompt: - name: backup_confirm prompt: 是否执行全量备份(y/n) private: no tasks: - name: 执行备份 command: /opt/full_backup.sh when: backup_confirm y综合实战案例OpenEuler集群升级--- - name: OpenEuler集群滚动升级 hosts: oel_cluster serial: {{ upgrade_batch | default(2) }} vars_prompt: - name: upgrade_confirm prompt: 确认开始集群升级(y/n) private: no tasks: - name: 中止任务未确认时 fail: msg: 用户取消升级操作 when: upgrade_confirm ! y - name: 委托到控制端生成升级计划 local_action: module: template src: upgrade_plan.j2 dest: /tmp/{{ inventory_hostname }}_plan.yaml run_once: true - name: 暂停确认每批次 pause: prompt: 确认升级批次 {{ ansible_batch_index }} seconds: 60 - name: 执行升级 yum: name: * state: latest environment: http_proxy: http://proxy:3128 - name: 委托到监控节点记录状态 command: /opt/log_upgrade.sh {{ inventory_hostname }} delegate_to: monitoring_server - name: 滚动重启 systemd: name: {{ item }} state: restarted loop: - docker - kubelet - sshd注意事项OpenEuler专属SELinux影响- name: 临时禁用SELinux selinux: state: permissive when: ansible_distribution openEulerA-Tune优化- name: 应用性能优化配置 copy: src: atune_profiles/webapp_profile.json dest: /etc/atuned/profiles/iSula容器支持- name: 重启iSula容器 isula: name: {{ container_name }} state: restarted

相关文章:

Ansible之Playbook(五):高级用法

Playbook高级用法一、本地执行(Local Action)应用场景当控制节点(非目标主机)需要执行特定操作时使用,如生成报告、处理临时文件等。OpenEuler实现方式- name: 在控制节点生成主机清单报告hosts: alltasks:- name: 收集…...

用于街头拍摄的摄像头

1 充电宝2 太阳能板我觉得用充电宝,物联网低功耗摄像头就可以了,因为录制的视频是等到拿回去以后再分析的,不用联网,联网是为了确保摄像头的安全,不被别人拿走。但是这个安装的过程:1 如果晚上12点去安装&a…...

未来5年最“钱“景岗位揭晓:AI产品经理,普通人如何从0到1逆袭?(内含3步进阶法+学习资源)

文章指出AI产品经理是未来5年最具潜力的岗位,并分析了想抓住AI机会的人常遇到的3种状态:观望者、探索者和跑偏者。文章将AI产品经理分为工具型、应用型和专业型,建议普通人以成为应用型AI产品经理为目标。文章提出了从入门到上手的3步学习法&…...

c++ string字符串详解

一.string背景以及需要了解的知识点 1.1STL string是STL的一部分,但是STL创建的比string晚一些,后面才把string加入到STL里。STL(standard template library)是c的重要组成部分,可以简单理解为一个囊括了数据结构里面我们学的结构与算法的集…...

AutoLisp实战:从零到一构建你的第一个绘图工具

1. 为什么选择AutoLisp来自动化绘图 如果你经常使用AutoCAD进行绘图工作,一定会遇到大量重复性的操作。比如每次都要手动选择两点画线,然后再单独添加标注。这种机械劳动不仅效率低下,还容易出错。AutoLisp就是AutoCAD内置的解决方案&#xf…...

Java-Study

基础环境搭建 下载jdk JDK 26 Documentation - Home JDK(Java Development Kit,Java 开发工具包) 是开发、编译、运行 Java 程序的核心基础环境,相当于你写 Java 代码的「工具箱 + 编译器 + 运行环境」三合一。 JDK 里到底有什么?(核心组成) JDK 不是一个单独的程序…...

如何科学构建TVA项目的成功标尺:从KPI设定到价值闭环

「本文已用流量券推广,欢迎收藏 关注」技术背景介绍:AI智能体视觉检测系统(TVA,全称为“Transformer-based Vision Agent”),即基于Transformer架构以及“因式智能体”创新理论的高精度视觉智能体&#xf…...

中国首部纯 AI 制作院线电影《第一大道》高清资源下载与观影指南

一、电影基本信息 《第一大道》是2026年推出的中国首部纯AI制作院线级史诗电影,由王铁编剧执导,全程采用字节跳动Seedance 2.0模型生成,片长150分钟,2K电影级画质(20481080),融合历史、权谋、科…...

Java工程师视角:j-langchain 快速上手 Agent

引言:为什么 Java 工程师也需要 Agent? 过去两年,几乎所有 AI Agent 教程都默认使用 Python。 你看到的往往是: LangChainLangGraphAutoGenCrewAI 但现实情况是,大多数企业后端系统并不是 Python,而是 Java…...

豆包 Rocky Linux 10.1 环境下 100 道 grep 命令高频面试题 + 详细答案

Rocky Linux 10.1 环境下 100 道 grep 命令高频面试题 + 详细答案 全部基于 GNU grep,可直接在 Rocky Linux 10.1 / RHEL 10 / CentOS Stream 上运行验证,覆盖基础、正则、递归、过滤、运维场景、性能与坑点。 一、基础用法(1–10) 1. grep 基本语法 答案 grep [选项] …...

Photon光影包深度技术解析:从物理渲染到游戏体验的全面优化方案

Photon光影包深度技术解析:从物理渲染到游戏体验的全面优化方案 【免费下载链接】photon A gameplay-focused shader pack for Minecraft 项目地址: https://gitcode.com/gh_mirrors/photon3/photon Photon是一个专注于游戏体验的Minecraft光影包&#xff0c…...

LVGL实战:5分钟用ESP32驱动ST7789屏幕打造智能家居控制面板(附完整代码)

ESP32LVGLST7789智能家居控制面板实战指南 1. 硬件准备与环境搭建 在开始之前,我们需要准备好所有必要的硬件组件。ESP32开发板因其强大的处理能力和丰富的接口资源,成为物联网项目的首选。ST7789则是一款性价比极高的TFT LCD驱动芯片,支持24…...

Maple_公式推导进阶:subs与isolate的高效应用技巧

1. Maple公式推导的核心优势 第一次接触Maple时,我被它纸面般的公式显示效果惊艳到了。这就像用钢笔在草稿纸上演算,但永远不用担心写错——因为随时可以按CtrlZ重来。在完成流体力学方程的推导项目后,我总结了Maple最打动工程师的四个特点&a…...

手把手教你用GD32的ADC+DMA实现多通道数据采集(含二分查找法优化技巧)

GD32多通道ADC数据采集实战:从DMA配置到二分查找优化 在嵌入式开发中,模拟信号采集是连接物理世界与数字系统的关键桥梁。GD32系列MCU凭借其高性能ADC模块和灵活的DMA控制器,为多通道数据采集提供了可靠解决方案。本文将带您从基础配置到高级…...

高项论文「范围管理」超详细写作攻略:从框架到字句,手把手教你写出高分答卷

前言:阅卷老师到底在看什么? 很多人认为论文是“玄学”,其实不然。范围管理论文的评分标准非常清晰,阅卷老师在几分钟内重点抓取以下5个关键得分维度:得分维度占比具体含义你的对策结构完整性20%6个子过程是否全部覆盖…...

如何用AI修复受损音频:VoiceFixer完整指南

如何用AI修复受损音频:VoiceFixer完整指南 【免费下载链接】voicefixer General Speech Restoration 项目地址: https://gitcode.com/gh_mirrors/vo/voicefixer 还在为嘈杂的录音、失真的语音或老旧音频而烦恼吗?VoiceFixer是你的AI音频修复专家&…...

如何快速通过手机号找回QQ账号:Python工具终极指南

如何快速通过手机号找回QQ账号:Python工具终极指南 【免费下载链接】phone2qq 项目地址: https://gitcode.com/gh_mirrors/ph/phone2qq 你是否曾经因为忘记QQ号而无法登录工作群聊,或者因为更换手机导致重要账号无法找回?现在&#x…...

Spring Boot 4 Spring Data AOT:从反射深渊到编译时确定性

我们是由枫哥组建的IT技术团队,成立于2017年,致力于帮助IT从业者提供实力,成功入职理想企业,我们提供一对一学习辅导,由知名大厂导师指导,分享Java技术、参与项目实战等服务,并为学员定制职业规…...

当医生意见不一时,AI怎么办?聊聊CVPR 2025 AmbiSSL如何解决医学图像分割的‘标注模糊’难题

当医生意见不一时,AI如何破局?解读CVPR 2025 AmbiSSL在医学图像分割中的创新实践 在放射科读片室里,三位资深医师正对同一张肺部CT片展开讨论。一位认为结节边缘需要扩大2mm勾画以确保安全切除,另一位坚持精确贴合可见边界&#x…...

AI声学A-59P模组:智能降噪,清晰通话

随着物联网与智能交互技术普及,语音已成为人机交互的主流入口。在楼宇对讲、车载通讯、远程会议、安防拾音等实际场景中,设备常面临稳态噪声(空调 / 风扇)、冲击噪声(敲击 / 碰撞)、风噪、交通噪声及强耦合…...

计算机网络 --- 动态路由

静态路由:由网络管理员手工配置的路由信息动态路由:所有路由器运行相同的路由协议,彼此之间沟通交流最终计算出到达未知网段的路由信息静态路由:优点:1.静态路由选路更加合理2.不需要额外消耗资源3.更加安全缺点&#…...

基于“灵珠AI平台”从0到1搭建一个博物馆数字人导游智能体教程

一、前言 有没有小伙伴去过博物馆?是不是经常遇到这种情况:租一个讲解器,走到哪听到哪,但它只管自己讲,根本不关心你想听什么。你对某件青铜器特别好奇,想多问两句?不好意思,讲解器不…...

寄存器与操作寄存器(小白级教学)

前言到目前为止,计算机依然只能读入二进制,此时肯定会有读者好奇了,那我们电脑中各种各样的图案,声音还有颜色都是如何来的呢,因为电脑本身就是硬件,硬件内部中,1就是代表高电压,0就…...

MyBatisPlus之核心功能+扩展功能

1.核心功能之Lamba更新普通写法:基于lamba写法:1.在controller层中编写接口,调用一个自己写的方法2.在IUserService接口,在UserServiceImpl实现该方法3.在UserServiceImpl编写代码,使用Lamba编写与lambdaQuery方法类似…...

用python实现一个简单的聊天功能

学完了python基础,写一个脚本,调用通义千问大模型API实现一个简单的聊天功能。 一、准备工作 1、执行以下命令,安装请求库 pip install requests 2、去通义千问开放平台申请API Key 注册阿里云账号并完成实名认证:https://das…...

Flutter 开源鸿蒙动效实战:全场景动效集成精简指南

🎉 Flutter 开源鸿蒙动效实战:全场景动效集成精简指南(鸿蒙兼容 可直接运行) 欢迎加入开源鸿蒙跨平台社区→https://openharmonycrosplatform.csdn.net 哈喽宝子们!我是刚学跨平台开发的大一新生😆 这次给我的鸿蒙 …...

别再裸奔了!给若依前后端分离项目加上AES接口加密(Vue3 + Spring Boot保姆级配置)

若依框架前后端分离项目AES接口加密实战指南 在当今数据安全日益重要的环境下,企业级应用开发中接口传输的安全性已成为不可忽视的一环。许多开发者在使用若依这类优秀框架时,往往只关注功能实现而忽略了数据传输过程中的安全隐患。本文将带您从零开始&a…...

D2: AI 工具的 ROI 评估框架(附 Excel 模板)

文章目录 D2: AI 工具的 ROI 评估框架(附 Excel 模板) 🎯 为什么这个话题重要? 现实痛点 真实案例 本章价值 核心内容 一、ROI 评估的核心公式 直接收益(可量化) 间接收益(需估算) 显性成本(必须计算) 隐性成本(最容易被低估) 风险成本(必须量化) 二、五维评估模…...

任务管理器怎么打开?【图文讲解】电脑卡死怎么关程序?任务管理器快捷键?电脑结束任务快捷键?6 种超简单方法,电脑卡死一键救急!

(1)问题背景 谁没碰到过电脑当场 “摆烂” 的崩溃时刻?软件卡死不动、页面关不掉、鼠标点啥都没反应,整个电脑卡成 PPT,急得人直跺脚! 这时候能救电脑于水火的,只有任务管理器。它就像电脑的急…...

BFF 架构决策与落地实践:从第一性原理到工程取舍

在主导过多个前后端分离项目的架构演进后,我对 BFF 这一层有了更系统的审视。它并非一个必须存在的组件,而是在特定约束下为解决特定问题而产生的架构模式。理解它,需要回到问题本源,厘清收益与代价,再谈如何落地。 一…...