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

用 Codex 写运维脚本(二)—— Prompt 工程:如何精准描述你的脚本需求

系列第二篇上一篇介绍了 Codex 对运维场景的价值本篇聚焦核心技能——如何写出高质量的提示词让 AI 一次输出可用脚本而不是反复拉锯。一、为什么提示词决定 80% 的脚本质量同样让 Codex 生成一个磁盘监控脚本看看两种写法的差距写法 A模糊帮我写个磁盘监控脚本输出结果一个df -h加简单echo的 10 行脚本没有告警、没有阈值、没有日志。写法 B结构化请用 Bash 写一个磁盘使用率监控脚本要求 - 检查所有挂载点的磁盘使用率 - 阈值使用率超过 85% 时告警 - 告警方式发送钉钉 Webhook 通知Webhook URL 通过环境变量 DINGTALK_WEBHOOK 读取 - 每次检查结果追加写入 /var/log/disk_monitor.log格式[时间戳] [挂载点] [使用率] - 脚本可直接加入 crontab每 5 分钟执行一次 - 包含错误处理curl 失败时记录错误日志但不退出输出结果一个带告警、带日志、带环境变量注入、带错误处理的生产级脚本。二、运维 Prompt 的黄金结构总结成一个公式【脚本类型】 【核心功能】 【输入/输出】 【异常处理】 【运行环境约束】 【输出格式要求】逐项拆解要素说明示例脚本类型Bash / Python / Ansible“请用 Python 3.8”核心功能动词 对象越具体越好“批量 SSH 登录并执行命令”输入/输出入参格式、输出位置“从 hosts.txt 读取 IP 列表结果输出到 result.csv”异常处理超时、失败、权限问题“单机失败不影响其他机器继续执行”运行环境约束OS 版本、Python 版本、依赖限制“只能用标准库不能安装第三方包”输出格式要求代码注释、函数封装等“每个函数加 docstring使用 argparse 解析参数”三、七个高效 Prompt 模板直接复用模板 1批量操作类请用 Bash 写一个脚本实现以下批量操作 目标对 hosts.txt 中的每台服务器每行一个 IP执行以下操作 1. 检查 [服务名] 服务状态 2. 如果服务未运行尝试启动并等待 10 秒 3. 再次检查状态仍未运行则记录为失败 输出生成 report_YYYYMMDD.txt包含每台机器的 IP、状态成功/失败、耗时 要求 - 最大并发 10 台 - SSH 超时设置 5 秒 - 失败的机器不影响其他机器继续执行 - 最终统计成功/失败数量模板 2日志处理类请用 Python 写一个日志分析脚本 输入/var/log/nginx/access.log标准 Nginx 日志格式 分析维度 1. 统计每个 URI 的请求次数按降序排列取 Top 20 2. 统计每小时请求量输出为时序数据 3. 找出响应时间超过 2 秒的请求记录 URI、时间、客户端 IP 输出 - 控制台打印 Top 20 URI 表格 - 生成 analysis_YYYYMMDD.json包含完整分析结果 依赖只用 Python 标准库re、collections、json、datetime模板 3监控告警类请用 Bash 写一个系统资源监控脚本 监控指标 - CPU 使用率1 分钟平均 - 内存使用率 - 磁盘 I/O wait 百分比 - TCP 连接数ESTABLISHED 状态 告警阈值 - CPU 90% - 内存 85% - I/O wait 30% - TCP 连接 1000 告警通道企业微信 WebhookURL 从 ENV 变量 WEIXIN_WEBHOOK 读取 执行方式可作为 crontab 每分钟调用重复告警间隔 10 分钟通过标志文件实现模板 4部署发布类请用 Bash 写一个应用部署脚本部署流程如下 1. 从参数 $1 读取版本号格式v1.2.3 2. 从 Nexus 下载对应版本的 JAR 包URL 模板${NEXUS_BASE_URL}/app-${version}.jar 3. 备份当前运行的 JAR备份到 /backup/app/ 4. 停止现有服务systemctl stop app-service等待最多 30 秒 5. 替换 JAR 包并启动服务 6. 健康检查请求 http://localhost:8080/health连续 3 次 200 则判定成功 7. 失败时自动回滚到备份版本 输出每个步骤打印带时间戳的进度日志模板 5定时清理类请用 Python 写一个文件清理脚本 清理规则从配置文件 cleanup.yaml 读取 - 支持配置多个目录 - 每个目录可单独配置保留天数、文件扩展名过滤、最小保留文件数 清理逻辑 - 按修改时间判断 - 确保每个目录至少保留最近 N 个文件即使超过天数限制 - 删除前打印将被删除的文件列表--dry-run 参数时只打印不删除 日志记录每次运行的删除文件数、释放空间MB到 SQLite 数据库支持查询历史记录模板 6数据同步类请用 Python 写一个数据库备份脚本 数据库MySQL 5.7 功能 1. 读取 /etc/backup/db_list.conf 中的数据库列表每行一个库名 2. 对每个库执行 mysqldump压缩为 gz 格式 3. 上传到阿里云 OSSBucket 名和 AK/SK 从环境变量读取 4. 保留本地最近 3 天备份OSS 保留 30 天 5. 备份完成后发送结果通知到钉钉 错误处理单个库失败不影响其他库最终汇总失败列表 依赖只允许使用 oss2、subprocess、logging不用其他第三方库模板 7巡检报告类请用 Python 生成一个服务器巡检脚本 巡检项目通过 SSH 连接执行 - 系统基本信息OS 版本、内核、运行时间 - CPU / 内存 / 磁盘使用率 - 僵尸进程数量 - 系统日志最近 100 行中的 ERROR/WARN 统计 - 开放端口列表 - 关键服务状态列表从配置文件读取服务名 输入从 inventory.csv 读取主机列表列ip, hostname, username, key_path 输出生成 HTML 格式的巡检报告包含汇总表和每机器详情 依赖paramiko、jinja2四、让输出质量翻倍的 5 个追加指令每次生成完基础脚本后用以下追加提示词进一步优化# 追加 1强化错误处理请检查脚本中所有可能失败的操作添加对应的错误处理和有意义的错误提示# 追加 2添加参数解析请为脚本添加命令行参数支持使用 argparsePython或 getoptsBash 并添加 --help 说明# 追加 3要求日志规范请将所有 echo/print 替换为标准日志格式[YYYY-MM-DD HH:MM:SS] [LEVEL] message 同时写入日志文件和标准输出# 追加 4生产安全加固请检查脚本的安全性避免明文密码、路径注入风险、权限最小化建议# 追加 5生成配套文档请为这个脚本生成使用说明包含功能描述、依赖安装、配置说明、使用示例、 注意事项五、常见踩坑 规避方法坑现象规避方法路径硬编码生成的脚本写死 /home/ubuntu在提示词中注明路径通过参数或环境变量传入依赖版本假设用了某些版本特有语法明确说明Python 3.8 或 “CentOS 7 的 Bash 4.x”缺少幂等性重复执行会出错要求脚本可重复执行已存在的资源跳过而不是报错密码明文直接把密码写在脚本里要求敏感信息从环境变量或 .env 文件读取无超时控制SSH/HTTP 请求永久阻塞要求所有网络操作设置超时SSH 超时 N 秒并发不可控同时操作几百台机器要求最大并发数通过参数控制默认 10六、小结Prompt 质量检查清单在发送提示词之前对照这个清单是否指定了脚本语言和版本是否描述了完整的输入来源和输出目标是否说明了错误处理预期是否提及了运行环境约束是否明确了敏感信息处理方式是否要求了幂等性如果需要达到 5/6 以上你的脚本生成质量会大幅提升。下一篇我们将直接动手用以上模板批量生成 5 个真实运维场景的 Shell 脚本逐行解析拿来即用。觉得有用请点赞收藏你的支持是持续更新的动力 ️

相关文章:

用 Codex 写运维脚本(二)—— Prompt 工程:如何精准描述你的脚本需求

系列第二篇:上一篇介绍了 Codex 对运维场景的价值,本篇聚焦核心技能——如何写出高质量的提示词,让 AI 一次输出可用脚本,而不是反复拉锯。一、为什么提示词决定 80% 的脚本质量? 同样让 Codex 生成一个"磁盘监控…...

用 Codex 写运维脚本(一)—— 为什么运维人需要 AI 代码生成?

一、你是否也有这样的日常? 每天打开终端,写的第一行代码大概率是这样的: #!/bin/bash set -euo pipefail然后开始漫长的复制-粘贴-改参数-踩坑循环。 批量重启服务?上次那个脚本在哪个 Wiki 页面……日志清理?上个…...

GPT-Image 2 登场:图像生成进入“思考”时代,设计行业格局将被重塑?

GPT-Image 2 震撼登场Sam Altman那个著名的梗,这次应验在所有人身上了。去年宣传GPT-5的时候,这位OpenAI的CEO说了一句后来被全网玩坏的话:“那种感觉,就像看到原子弹爆炸,整个人眩晕瘫坐。”此后每逢AI圈发布新品、配…...

【2026最稀缺CUDA专家认证考点】:CUDA Graph 3.0动态图优化、Kernel Fusion自动识别、Tensor Core利用率>92%的硬核调参公式

https://intelliparadigm.com 第一章:CUDA 13统一内存架构与AI算子优化范式跃迁 CUDA 13 引入了重构级的统一内存(Unified Memory, UM)增强机制,通过硬件协同的内存访问预测器(Memory Access Predictor, MAP&#xff…...

AMD Ryzen处理器调校终极指南:用SMUDebugTool解锁隐藏性能潜能

AMD Ryzen处理器调校终极指南:用SMUDebugTool解锁隐藏性能潜能 【免费下载链接】SMUDebugTool A dedicated tool to help write/read various parameters of Ryzen-based systems, such as manual overclock, SMU, PCI, CPUID, MSR and Power Table. 项目地址: ht…...

【C++26元编程革命】:从SFINAE到`reflexpr`——6步迁移路径图+可运行模板库源码

第一章:C26元编程革命的范式跃迁C26 正在重塑元编程的底层契约——从依赖模板递归与 SFINAE 的“技巧型”编码,转向以编译期计算为一等公民、语义清晰且可调试的声明式范式。核心驱动力来自 constexpr 语义的彻底强化、std::meta 库的标准化落地&#xf…...

Sockeye:基于硬件手册的SoC安全验证工具解析

1. Sockeye:基于硬件手册的SoC安全验证革命在处理器安全领域,我们正面临一个尴尬的现实:现代SoC(系统级芯片)的参考手册平均包含超过3000页的技术描述,而其中关键的安全机制说明往往分散在不同章节&#xf…...

光伏Boost电路硬件设计避坑指南:从5mH电感选型到IGBT驱动,一个实例讲透

光伏Boost电路硬件设计实战:从电感选型到IGBT驱动的关键细节 光伏发电系统的前级Boost电路设计看似简单,实则暗藏玄机。当输入电压在50V到150V之间大幅波动时,每个元器件的选型都直接影响系统稳定性和寿命。本文将基于1000W光伏系统的真实案例…...

职场学习投资:如何说服老板为你的成长买单

1. 职场学习投资的价值认知在知识迭代速度呈指数级增长的今天,持续学习已成为职场人保持竞争力的刚需。根据领英2023年职场学习报告显示,87%的经理人认为员工技能提升速度直接影响团队绩效,但仅有35%的企业建立了系统的学习资助机制。这种供需…...

机器人控制系统中工控机的选型要点(2026新版)

阿强带你了解机器人控制系统中工控机的选型要点。机器人控制系统是机器人的核心,而工控机又是机器人控制系统的核心。工控机的选型直接决定了机器人控制系统的性能、稳定性和可靠性。很多人在选型的时候,往往只关注处理器的主频和核心数,忽略…...

别再死磕梯度下降了!用Python遗传算法搞定复杂函数极值,保姆级代码拆解

遗传算法实战:用Python突破传统优化方法的局限性 当面对复杂的优化问题时,工程师们常常会陷入梯度下降等传统方法的困境。想象一下这样的场景:你需要优化的函数像一座崎岖的山脉,有无数个峰谷,而且函数在某些点甚至不可…...

机器学习模型监控:核心价值与五大趋势解析

1. 模型监控实践的核心价值在机器学习工程化的落地过程中,模型监控往往是最容易被忽视却至关重要的环节。我见过太多团队花费数月训练出高精度模型,上线后却因为缺乏有效监控导致业务指标不升反降的案例。模型监控本质上是对模型生产环境的"健康体检…...

别再只看分辨率了!工程师实战分享:从AD7606看ADC选型必须死磕的6个参数(附避坑清单)

嵌入式工程师的ADC选型实战指南:超越分辨率的6个关键维度 当我在去年负责一个工业传感器项目时,团队曾因为ADC选型失误导致整个硬件方案推倒重来——我们选择了一款16位高分辨率ADC,却在样机测试阶段发现其输入范围无法兼容现场设备的10V信号…...

告别ifconfig:用ip命令和rfkill更优雅地管理你的Linux无线网络(CentOS/Ubuntu实测)

现代Linux无线网络管理:从ifconfig到ip与rfkill的进阶实践 在Linux系统管理中,网络配置一直是核心技能之一。多年来,ifconfig命令一直是网络管理员和开发者的标配工具,但随着Linux内核和网络栈的演进,这套传统工具链正…...

用立创EDA复刻经典:手把手教你搭建一个带数码管显示的正弦波发生器(附完整原理图)

用立创EDA复刻经典:手把手教你搭建一个带数码管显示的正弦波发生器 在电子工程领域,经典电路设计永不过时。当你翻开任何一本模拟电路教材,RC桥式振荡器、555定时器、数码管显示这些基础模块总是占据重要篇幅。但时代在进步,传统的…...

AI超级员工选型:2026年5款高性价比工具实测解析

2026年,人工智能已从大型企业的技术专属,变为中小企业降本增效、突破增长瓶颈的核心生产力。行业实测数据显示,完成AI超级员工系统部署的中小企业,平均获客成本降低60%,运营效率提升120%,整体投入仅为传统人…...

用Wireshark抓包分析极域电子教室V6.0 2016豪华版,手把手教你实现学生机互控

极域电子教室V6.0协议深度解析:从抓包到自主控制的全链路实践 在校园信息化建设中,电子教室系统承担着教学管理的重要角色。作为国内广泛部署的解决方案,极域电子教室V6.0 2016豪华版采用独特的UDP广播机制实现师生端通信。本文将系统性地展示…...

用74LS160和74LS85芯片手搓一个带闹钟的数字钟(附Multisim仿真文件)

基于74LS系列芯片的数字钟设计与实现全解析 在电子技术飞速发展的今天,数字电路设计依然是电子工程师和爱好者的必修课。本文将带您深入探索如何利用经典的74LS160计数器和74LS85比较器芯片,从零开始构建一个功能完备的数字时钟系统。这个项目不仅涵盖了…...

Marp架构深度解析:构建现代化Markdown演示文稿的技术实现方案

Marp架构深度解析:构建现代化Markdown演示文稿的技术实现方案 【免费下载链接】marp The entrance repository of Markdown presentation ecosystem 项目地址: https://gitcode.com/gh_mirrors/mar/marp Marp(Markdown Presentation Ecosystem&am…...

Unity架构模式实战:从MVC到MVVM的演进与选型指南

1. 为什么需要架构模式? 刚开始接触Unity开发时,我最常干的事情就是把所有代码都塞进一个脚本里。比如做个简单的计数器功能,UI显示、按钮交互、数据存储全都写在一个MonoBehaviour里。这样确实能快速实现功能,但随着项目规模扩大…...

免费开源CAD软件LitCAD:如何用轻量级工具完成专业二维绘图?[特殊字符]

免费开源CAD软件LitCAD:如何用轻量级工具完成专业二维绘图?🚀 【免费下载链接】LitCAD A very simple CAD developed by C#. 项目地址: https://gitcode.com/gh_mirrors/li/LitCAD 你是否正在寻找一款完全免费、易于上手却功能强大的C…...

Ubuntu上Snap进程CPU飙升100%?别慌,三步排查清理搞定(附df -h详解)

Ubuntu上Snap进程CPU飙升100%?三步诊断与深度清理指南 上周三凌晨两点,我的Ubuntu工作站突然像被灌了铅——编译任务卡在fatal error: cant write PCH file: 设备上没有空间,VSCode的响应延迟飙到令人发指的程度。作为常年与Linux打交道的开发…...

MATLAB老用户看过来:手把手教你下载配置DeepLearnToolbox,重温经典深度学习工具箱

MATLAB经典深度学习工具箱DeepLearnToolbox的现代适配指南 引言:为何还要关注这个"过时"的工具箱? 在TensorFlow和PyTorch主导的深度学习时代,我们为何还要讨论一个MATLAB环境下已停止维护的工具箱?答案可能藏在这些场景…...

空间机器人线性导轨测试台设计与动力学验证

1. 线性导轨测试台设计背景与核心挑战在轨服务、组装与制造(ISAM)技术正在彻底改变空间资产的应用模式。想象一下,未来卫星不再是一次性使用的设备,而是可以像汽车一样进行维修、升级甚至重构的模块化平台。这种变革的核心在于空间…...

从实验室到生产:手把手教你用 OVS 在 Ubuntu 上快速搭建一个可用的虚拟网络沙盒

从实验室到生产:手把手教你用 OVS 在 Ubuntu 上快速搭建虚拟网络沙盒 在软件定义网络(SDN)和云计算领域,Open vSwitch(OVS)已经成为构建虚拟网络的事实标准工具。不同于传统物理交换机,OVS提供了…...

从手机开机到上网:一文读懂LTE/5G中MIB和SIB消息的“寻路”过程

从手机开机到上网:LTE/5G中MIB和SIB消息的寻路之旅 当清晨按下手机电源键的那一刻,一场精密的无线通信交响乐便悄然奏响。这部搭载现代通信技术的智能设备,正以毫秒级的速度执行着从开机到接入蜂窝网络的复杂流程。本文将带您深入探索智能手机…...

告别打包体积焦虑:用@babel/preset-env和core-js 3.x精准引入Polyfill(附targets配置详解)

现代前端工程中的Polyfill精准引入策略与实践 在当今快速迭代的前端生态中,开发者们常常面临一个两难选择:要么为了保证兼容性而全量引入Polyfill导致包体积膨胀,要么为了性能而放弃对老旧浏览器的支持。这种困境在需要兼顾多种终端设备的项目…...

别再死磕adb disable-verity了!遇到‘USER build’报错,试试这个fastboot方案

突破Android USER构建限制:fastboot替代adb的深度解决方案 当你在Android设备上尝试执行adb disable-verity命令时,遇到"verity cannot be disabled/enabled - USER build"报错,这往往意味着你正面对Google在Android安全架构中设置…...

低成本物联网网关方案:全志A40i + RTL8188FU WiFi模块的选型、驱动与性能实测

低成本物联网网关实战:全志A40i与RTL8188FU模块的选型优化与性能调校 当你在设计一款面向工业现场的物联网边缘设备时,WiFi连接的稳定性和成本控制往往成为一对矛盾体。全志A40i这颗国产SoC以其出色的性价比和丰富的接口资源,成为许多嵌入式开…...

从器件选型到波形优化:基于ADS的Marx雪崩脉冲源全链路设计实践

1. 雪崩三极管选型:从参数表到实战筛选 设计纳秒级高压脉冲源的第一步,就是选择合适的雪崩三极管。这就像盖房子要选好地基材料一样,器件选型直接决定了整个系统的性能上限。我在实际项目中踩过不少坑,发现很多新手容易陷入两个极…...