系统管理员AI编程实战:基于Claude的运维自动化脚本开发指南

news2026/5/17 3:27:43
1. 项目概述一个面向系统管理员的Claude-Code学习与实践仓库最近在整理自己的技术栈时发现很多系统管理员同行对如何将大型语言模型LLM高效地融入日常运维工作流感到困惑。大家普遍觉得这些AI工具很强大但具体到写脚本、分析日志、排查故障时又不知道从哪里下手或者写出来的提示词Prompt效果不佳。这正是我创建并维护sysnet4admin/_Book_Claude-Code这个GitHub仓库的初衷。它不是一个简单的代码合集而是一个专门为系统管理员SysAdmin和运维工程师DevOps量身打造的基于Anthropic Claude特别是其代码生成与理解能力强大的版本的实战指南与案例库。这个仓库的核心目标非常明确降低系统管理员使用AI编码工具的门槛提升运维自动化脚本的开发效率与质量。我们每天面对的是繁杂的服务器配置、周期性的日志巡检、突发的性能瓶颈以及永无止境的安全补丁。传统上解决这些问题依赖于个人经验、社区脚本和大量的手动调试。而现在像Claude这样的AI助手能够理解我们的自然语言描述并生成可运行的Shell、Python、PowerShell脚本这无疑是一场效率革命。但问题在于如何与AI“有效沟通”让它生成真正符合生产环境要求、安全、健壮的代码而不是看起来能跑但充满隐患的“玩具脚本”。这个仓库就是我过去一年多在真实生产环境中反复摸索、试错、优化后沉淀下来的经验结晶。它适合所有希望用AI提升工作效率的系统运维人员无论你是刚接触自动化脚本的新手还是希望将AI集成到现有CI/CD流水线中的资深工程师。仓库里的内容不是枯燥的理论而是围绕一个个具体的运维场景展开比如“如何用Claude快速生成一个安全的用户批量创建脚本”、“如何让AI帮你写一个带错误重试和日志记录的备份脚本”、“如何优化一个已有的性能监控脚本”等等。每一个案例都包含了我精心设计的提示词模板、生成的代码样例、详细的代码解读以及最重要的——我在实际使用中踩过的坑和总结的优化技巧。接下来我将详细拆解这个仓库的设计思路、核心内容以及如何最大化地利用它来武装你的日常运维工作。2. 仓库结构与核心内容设计解析2.1 为什么采用“场景驱动”而非“语言驱动”的目录结构打开sysnet4admin/_Book_Claude-Code仓库你首先会发现它的目录结构不是按编程语言如bash/,python/,powershell/来划分的而是按运维工作场景来组织的。这是经过深思熟虑的设计其背后有深刻的逻辑。对于系统管理员而言我们首先思考的是“我要解决什么问题”而不是“我要用什么语言”。例如当面临“磁盘空间告警”时我们的需求是1) 快速定位哪个目录或文件系统空间不足2) 找出占用空间最大的文件或目录3) 安全地清理或归档旧数据4) 可能还需要发送通知。这是一个完整的场景。如果按语言分用户需要分别在Bash和Python目录下寻找相关脚本思维是割裂的。而按场景分比如在01-Filesystem-Disk-Management/目录下你会看到针对这个场景的一整套解决方案可能包含一个用Bash写的快速定位脚本因为Bash在处理管道和系统命令时极其高效一个用Python写的带详细报告和邮件通知的增强版脚本以及一个专门用于清理特定类型日志文件的PowerShell脚本如果在Windows环境下。所有相关代码、提示词和说明都聚集在一起方便你对比、选择和组合使用。这种结构极大地降低了学习成本。你不需要先成为Python或Bash专家你只需要清楚自己的运维场景就能直接找到对应的“工具箱”。每个场景目录下通常包含以下几个核心文件README.md: 场景概述、核心挑战、AI辅助解决的思路。prompt_template.md: 针对该场景优化过的提示词模板这是与AI高效沟通的“秘方”。generated_script_*.sh/.py/.ps1: 由Claude根据提示词生成的示例脚本。script_breakdown.md: 对生成脚本的逐行解读解释关键代码段的作用、潜在风险以及为什么这样写。common_issues.md: 在该场景下使用AI生成代码时常见的“翻车”点及修正方法。2.2 提示词工程教会AI用运维的思维写代码这个仓库最精华的部分莫过于那些经过千锤百炼的提示词模板。很多人抱怨AI生成的代码不好用往往是因为提问的方式太笼统。对AI说“写一个监控磁盘的脚本”它可能给你一个最简单的df -h输出。但这离生产要求相差甚远。我们的提示词设计遵循“角色扮演 约束条件 示例输出”的框架。以“生成一个Linux服务器磁盘空间检查脚本”为例一个初级的提示词可能是“写一个Bash脚本来检查磁盘使用率。” 而在本仓库中对应的提示词模板会是这样你是一名经验丰富的Linux系统管理员擅长编写安全、健壮、易于维护的Shell脚本。 任务编写一个用于生产环境Linux服务器的磁盘空间检查脚本。 具体要求 1. 脚本目标检查指定文件系统默认为/根分区的使用率当超过85%阈值时发出警告超过95%时发出严重警报。 2. 输出要求脚本应输出清晰的JSON格式包含以下字段filesystem, size, used, available, use_percentage, statusOK/WARNING/CRITICAL。这便于被其他监控系统如Zabbix、Prometheus解析。 3. 健壮性要求 - 必须包含完善的错误处理。如果df命令执行失败脚本应捕获错误并退出返回非零状态码。 - 使用set -euo pipefail确保脚本在遇到未初始化变量、错误或管道失败时立即退出。 - 对df命令的输出进行解析时要处理可能存在的空格和换行符避免解析错误。 4. 可配置性允许通过命令行参数 -t WARNING_THRESHOLD 和 -c CRITICAL_THRESHOLD 来覆盖默认阈值。 5. 安全提示在脚本注释中提醒用户该脚本需要读取系统磁盘信息应以具有适当权限的用户身份运行。 请先生成脚本的完整代码然后对关键代码段进行简要解释特别是错误处理和JSON生成部分。这个提示词的妙处在于角色定位首先将AI设定为“经验丰富的系统管理员”这会让它倾向于使用更专业、更符合运维习惯的写法。场景化约束明确是“生产环境”暗示代码需要高可靠性。具体化要求不仅说了“检查”还明确了阈值、输出格式JSON这是为了集成、状态分类。嵌入最佳实践直接要求使用set -euo pipefail这是编写可靠Bash脚本的金科玉律避免了AI生成一些松散、危险的代码。考虑可维护性与集成要求命令行参数和JSON输出使得脚本不再是孤立的而是可以轻松融入现有的自动化工具链。通过这样的提示词Claude生成的代码质量会有一个质的飞跃。仓库中的每个提示词模板都是这样打磨出来的它们本身就是一份宝贵的“如何向AI描述运维需求”的教科书。2.3 代码解读与“思维链”展示生成代码只是第一步。对于使用者尤其是新手理解“为什么代码要这样写”比拿到代码本身更重要。因此仓库中每个主要脚本都配有详细的script_breakdown.md文件。这个文件不会简单地重复代码注释而是采用“运维视角”进行解读。它会重点分析安全性与风险点例如指出脚本中某个使用了rm -rf的命令为什么前面要加倍检查路径变量是否为空以及如何防止路径遍历攻击。性能考量在解析大型日志文件时为什么选择使用awk或grep -m而不是全部读入内存的Python方法。兼容性说明脚本中使用的某个命令或语法如#!/usr/bin/env bash与#!/bin/bash的区别或mapfile命令适用于哪些Linux发行版或Bash版本。扩展性建议指出脚本的哪些部分可以轻松修改以适应类似场景比如如何将监控的磁盘从根分区扩展到多个数据盘。更重要的是我们会展示“思维链”。即如果对生成的脚本有不满意的地方如何通过多轮对话让AI进行迭代优化。例如第一版脚本可能没有日志功能我们会在下一轮提示中说“很好现在请为这个脚本添加日志功能要求将警告和严重警报记录到/var/log/disk_monitor.log并包含时间戳和主机名。” 并把AI的改进过程和最终代码都记录下来。这个过程教会用户的是如何像“技术负责人”一样审查和引导AI的产出这才是真正的赋能。3. 核心运维场景实战案例深度剖析3.1 场景一自动化用户与权限管理用户管理是系统管理员的基础工作但也是最繁琐、最容易出错的工作之一。尤其是当需要批量创建数十上百个用户并为他们配置不同的主目录、登录Shell、附属组和sudo权限时手动操作不仅效率低下而且一致性无法保证。在仓库的02-User-Group-Management/目录下我们提供了从简单到复杂的系列解决方案。基础版本是一个Bash脚本它从一个格式化的CSV文件包含用户名、UID、主组、附属组等信息中读取数据然后使用useradd、usermod、passwd等命令批量创建用户。提示词的关键在于强制AI考虑以下运维细节幂等性脚本在运行前必须检查用户是否已存在。如果存在是跳过、报错还是进行更新我们通常选择“跳过并记录警告”以保证脚本可安全重复执行。密码安全绝对禁止在脚本中硬编码密码或生成弱密码。我们的提示词会要求AI采用两种安全方式1) 为每个用户生成一个随机强密码并输出到加密文件提示用户首次登录后修改2) 或者更佳实践是设置账户为初始禁用状态然后通过单独的、安全的渠道分发一次性登录令牌。审计日志脚本必须详细记录每一步操作创建了谁、分配了什么权限、是否成功到系统日志如/var/log/secure和一个独立的操作日志文件中以满足安全审计要求。回滚机制进阶对于更复杂的场景我们甚至引导AI编写一个带有“预检查”和“回滚”功能的版本。脚本会先模拟运行dry-run列出所有将要执行的操作经确认后才实际执行。如果中途任何一步失败脚本应能自动或手动执行回滚操作删除已创建的用户恢复到之前的状态。这个案例的启示是通过精心设计的提示词我们可以让AI生成不仅仅是“能跑”的代码而是符合企业级运维规范、具备生产就绪性Production-Ready的代码。3.2 场景二日志分析与实时监控告警日志是运维的“眼睛”。但面对GB甚至TB级别的日志文件如何快速定位问题仓库的03-Log-Monitoring-Analysis/场景提供了多种模式。模式A离线批量分析。针对诸如“找出过去24小时内访问频率最高的前10个IP地址”或“统计某种错误码出现的次数”这类需求我们提供Python脚本模板。提示词会要求AI使用collections.Counter或pandas库进行高效统计并强调处理大文件时应使用逐行读取with open(...) as f: for line in f:而非readlines()以避免内存溢出。同时脚本要能接受通配符指定的多个日志文件作为输入。模式B实时尾部监控与模式匹配。这是更动态的需求比如监控应用日志当出现“OutOfMemoryError”或“Connection timeout”时立即发出告警。这里我们展示如何用AI编写一个类似tail -f但更智能的Python脚本。提示词的核心要点包括使用time.sleep()进行轮询还是用select或asyncio实现事件驱动我们会解释在简单场景下轮询的实用性并给出示例。如何高效地进行正则表达式匹配并提取关键上下文信息如错误发生前后的若干行日志。如何集成告警通道脚本模板会预留接口可以轻松接入发送邮件、调用Webhook如钉钉、企业微信、Slack机器人或写入告警平台的功能。一个关键的实操心得在让AI生成正则表达式时一定要提供足够多的、多样化的真实日志样例。否则AI生成的正则可能过于严格或宽松。最好的做法是先在提示词里粘贴5-10条包含目标模式和不包含目标模式的日志行让AI“学习”你日志的格式然后再让它生成匹配规则。仓库里有一个专门的log_samples.txt文件就是用于这个目的。3.3 场景三跨平台脚本与配置模板生成现代运维环境往往是异构的同时存在Linux和Windows服务器。如何让AI写出兼容性好的脚本或者为不同系统生成对应的配置04-Cross-Platform-Configuration/场景探讨了这个问题。例如我们需要一个统一管理工具在Linux上安装并启动Nginx在Windows上安装并启动IIS。一个粗糙的提示词会导致AI生成两个完全独立的脚本。而我们的高级提示词会引导AI编写一个分发控制器脚本可能是Python或Ansible这个脚本首先通过platform.system()或类似方法检测目标操作系统然后动态调用或生成对应的平台专用脚本模块。更进阶的应用是配置模板渲染。比如为不同的服务器生成不同的nginx.conf或prometheus.yml。我们会教用户如何构建一个“数据模型”通常是一个YAML或JSON文件描述服务器角色、监听端口、上游服务器列表等然后让AI基于Jinja2模板语法编写一个模板渲染脚本。提示词会详细说明数据模型的结构和模板中需要的控制逻辑如循环、条件判断。这样你只需维护一份数据模型和一份模板就能批量生成所有服务器的配置文件极大地保证了配置的一致性和可维护性。AI在这里的角色从“写一次性脚本”升级为“帮我们构建可复用的自动化资产”。4. 高级技巧将Claude-Code集成到运维工作流4.1 在CI/CD流水线中引入AI代码审查生成的脚本最终要投入生产使用那么它的质量如何保证除了人工审查我们还可以在GitLab CI/CD或Jenkins Pipeline中引入一个“AI辅助审查”阶段。这个想法听起来很前沿但实现起来有章可循。我们可以在仓库中提供一个.gitlab-ci.yml或Jenkinsfile的示例模板。在这个模板中定义一个新的CI阶段例如叫ai-review。该阶段的任务是提取本次提交中新增或修改的脚本文件。将这些脚本文件的内容连同我们预设的“运维脚本安全检查清单”一起构造一个提示词发送给Claude的API或其他具备代码分析能力的LLM API。“安全检查清单”可能包括是否使用了不安全的命令如直接拼接变量执行、是否有未处理的错误、是否存在硬编码的敏感信息、是否符合ShellCheck规范等。让AI分析脚本并生成一个审查报告指出潜在的风险、不符合最佳实践的地方甚至给出修改建议。这个报告可以作为Pipeline的一个Artifact产出供开发者参考也可以设置规则如果AI发现高危问题如明显的命令注入漏洞则让Pipeline失败强制修改。这相当于为你的脚本仓库增加了一个24小时在线的、知识渊博的自动化代码审查员。仓库中会提供这个集成方案的详细配置步骤和示例提示词。4.2 构建个人或团队的提示词知识库随着使用场景的增多高效的提示词会成为团队最重要的资产。我们不应该每次都从头开始写提示词。仓库本身就是一个优秀的提示词库但你可以在此基础上利用现有的Markdown文件构建一个更易查询和使用的知识库。一个简单的实践是使用像Obsidian或Logseq这样的双链笔记工具将每个场景的prompt_template.md文件导入。然后为每个提示词打上标签如#bash、#user-management、#monitoring、#safe。当你需要编写一个新的磁盘清理脚本时你可以在笔记中搜索#bash #disk #safe立刻找到相关的历史提示词作为起点稍作修改就能使用效率倍增。对于团队可以建立一个内部的Git仓库专门存放经过验证的、针对公司特定环境如内部软件名称、特定目录结构优化过的提示词模板。新同事入职后首先学习的就是这个“如何让AI为我们工作”的知识库这能极大缩短培训周期统一团队的脚本开发标准。4.3 处理AI的“幻觉”与生成代码的验证这是使用任何AI编码工具都无法回避的问题。Claude-Code虽然强大但偶尔也会产生“幻觉”Hallucination即生成看似合理但实际不存在或功能错误的代码片段比如一个不存在的Linux命令参数或者一个错误的API用法。应对策略一要求AI提供解释与来源。在提示词中明确要求“请为脚本中使用的每个非内置命令或复杂逻辑块提供简要解释并注明其常见的Linux手册页章节或官方文档链接。” 这不仅能帮助AI进行自我验证也方便你后续人工核对。应对策略二分步验证与沙盒测试。永远不要直接将AI生成的一大段复杂脚本在生产环境运行。我们的工作流应该是生成获得AI生成的脚本。分解如果是长脚本要求AI将其分解为几个功能独立的函数或模块。单元测试在提示词中要求AI为每个关键函数编写简单的测试用例例如使用Bash的[[ ]]测试或Python的assert语句。你可以在一个安全的沙盒环境如Docker容器、虚拟机快照中运行这些测试。集成测试将脚本在预发布环境或与生产环境高度相似的测试环境中用模拟数据或小流量真实数据跑一遍。应对策略三交叉验证。对于非常关键或复杂的逻辑可以用同样的需求去询问另一个AI模型如ChatGPT的代码解释器比较两者生成的代码。如果核心逻辑一致那么可信度就高很多如果差异很大就需要你深入研究判断哪种方案更优。仓库里记录了几个通过交叉验证发现并纠正AI“幻觉”的真实案例。5. 常见问题、排查技巧与避坑指南在实际使用sysnet4admin/_Book_Claude-Code仓库和与Claude协作的过程中我积累了大量的一手经验。以下是一些最常见的问题和解决思路这可能是比代码本身更有价值的部分。5.1 生成的脚本权限不足或路径错误问题现象脚本在手动测试时运行良好但放入cron定时任务或由CI/CD工具调用时提示“命令未找到”或“权限被拒绝”。根因分析环境变量差异交互式Shell如bash会加载~/.bashrc等配置文件其中设置了PATH等环境变量。而非交互式环境如cron、CI Runner加载的环境变量非常有限可能不包含/usr/local/bin、/snap/bin等路径。工作目录不同脚本中使用了相对路径如./config.ini在cron中执行时工作目录可能是用户的家目录或根目录导致找不到文件。解决方案与提示词技巧在提示词中明确环境开头就声明“此脚本将用于非交互式环境如cron定时任务”。强制使用绝对路径要求AI“在脚本中对所有外部命令如python3,docker,awk使用绝对路径例如/usr/bin/python3或至少在脚本开头显式设置PATH环境变量export PATH/usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/sbin:/bin”。处理工作目录要求脚本“在读取任何配置文件或写入日志文件时必须使用绝对路径或者使用dirname $0获取脚本所在目录并基于此构建绝对路径”。5.2 AI生成的代码过于冗长或存在冗余问题现象AI生成的脚本能完成任务但代码行数很多逻辑绕弯存在不必要的变量或检查。根因分析AI在力求“健壮”和“全面”时可能会过度设计添加了很多针对边缘情况的处理而这些情况在你的特定环境中可能永远不会发生。解决方案与提示词技巧设定简洁性要求在提示词中加入“请优先考虑代码的简洁性与可读性在保证核心功能正确和安全的前提下避免过度工程化。”进行多轮迭代优化第一轮生成基础可用脚本后第二轮提示词可以聚焦优化“现在请审视刚才生成的脚本找出可以简化或合并的代码段目标是减少20%的代码行数同时不牺牲核心功能和错误处理。” AI通常很擅长做这种重构。提供代码风格指南可以告诉AI“请遵循Google的Shell/Python风格指南编写代码”这通常会使生成的代码结构更清晰、更规范。5.3 处理包含敏感信息的脚本问题现象脚本中需要连接数据库、调用API这些操作需要密码、令牌等敏感信息。直接硬编码在脚本里是严重的安全隐患。解决方案与提示词技巧绝对禁止硬编码在提示词中作为铁律提出“脚本中严禁以任何形式硬编码密码、API密钥、令牌等敏感信息。”引导使用安全方式要求AI采用以下一种或多种模式环境变量db_password${DB_PASSWORD:-}并通过注释说明如何设置环境变量。配置文件从受权限保护的独立配置文件如~/.app/config.yaml中读取脚本负责检查文件权限如是否chmod 600。密钥管理服务提示脚本可以从HashiCorp Vault、AWS Secrets Manager等服务动态获取密钥这需要更复杂的提示词描述集成方式。生成配套的部署说明要求AI在生成脚本后额外生成一份DEPLOYMENT.md详细说明如何安全地设置所需的环境变量或配置文件。5.4 让AI理解复杂的现有代码或日志格式问题现象你想让AI帮你优化一个已有的、复杂的Perl脚本或者分析一种自定义格式的应用程序日志但AI由于缺乏上下文而无法理解。解决方案与提示词技巧提供充足的上下文不要只说“优化这个脚本”。将整个脚本内容粘贴到提示词中并在此之前用自然语言描述它的主要功能、核心痛点比如“它跑得太慢了”或“错误处理不完善”以及运行环境。进行“分而治之”的提问如果脚本非常长不要一次性让AI处理全部。可以这样说“以下是脚本的第一部分负责数据读取和解析。请先分析这部分代码是否存在性能瓶颈或潜在bug。” 等它分析完第一部分再提交第二部分。为自定义日志格式提供“样本数据”和“数据字典”在让AI编写日志分析脚本前先提供一个sample_logs.txt文件里面包含10-20条有代表性的日志行包括正常和异常情况。同时提供一个log_format_spec.md文件用表格形式解释日志中每个字段的含义、数据类型和可能的值。例如字段位置字段名示例说明1时间戳2023-10-27T14:32:01.123ZISO 8601格式2日志级别ERRORDEBUG, INFO, WARN, ERROR, FATAL3请求IDreq-abc123唯一标识一次请求4错误码ERR_CONN_TIMEOUT自定义错误码当AI拥有了这些上下文后它生成的正则表达式或解析逻辑的准确率会大大提高。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/2620288.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

SpringBoot-17-MyBatis动态SQL标签之常用标签

文章目录 1 代码1.1 实体User.java1.2 接口UserMapper.java1.3 映射UserMapper.xml1.3.1 标签if1.3.2 标签if和where1.3.3 标签choose和when和otherwise1.4 UserController.java2 常用动态SQL标签2.1 标签set2.1.1 UserMapper.java2.1.2 UserMapper.xml2.1.3 UserController.ja…

wordpress后台更新后 前端没变化的解决方法

使用siteground主机的wordpress网站,会出现更新了网站内容和修改了php模板文件、js文件、css文件、图片文件后,网站没有变化的情况。 不熟悉siteground主机的新手,遇到这个问题,就很抓狂,明明是哪都没操作错误&#x…

网络编程(Modbus进阶)

思维导图 Modbus RTU(先学一点理论) 概念 Modbus RTU 是工业自动化领域 最广泛应用的串行通信协议,由 Modicon 公司(现施耐德电气)于 1979 年推出。它以 高效率、强健性、易实现的特点成为工业控制系统的通信标准。 包…

UE5 学习系列(二)用户操作界面及介绍

这篇博客是 UE5 学习系列博客的第二篇,在第一篇的基础上展开这篇内容。博客参考的 B 站视频资料和第一篇的链接如下: 【Note】:如果你已经完成安装等操作,可以只执行第一篇博客中 2. 新建一个空白游戏项目 章节操作,重…

IDEA运行Tomcat出现乱码问题解决汇总

最近正值期末周,有很多同学在写期末Java web作业时,运行tomcat出现乱码问题,经过多次解决与研究,我做了如下整理: 原因: IDEA本身编码与tomcat的编码与Windows编码不同导致,Windows 系统控制台…

利用最小二乘法找圆心和半径

#include <iostream> #include <vector> #include <cmath> #include <Eigen/Dense> // 需安装Eigen库用于矩阵运算 // 定义点结构 struct Point { double x, y; Point(double x_, double y_) : x(x_), y(y_) {} }; // 最小二乘法求圆心和半径 …

使用docker在3台服务器上搭建基于redis 6.x的一主两从三台均是哨兵模式

一、环境及版本说明 如果服务器已经安装了docker,则忽略此步骤,如果没有安装,则可以按照一下方式安装: 1. 在线安装(有互联网环境): 请看我这篇文章 传送阵>> 点我查看 2. 离线安装(内网环境):请看我这篇文章 传送阵>> 点我查看 说明&#xff1a;假设每台服务器已…

XML Group端口详解

在XML数据映射过程中&#xff0c;经常需要对数据进行分组聚合操作。例如&#xff0c;当处理包含多个物料明细的XML文件时&#xff0c;可能需要将相同物料号的明细归为一组&#xff0c;或对相同物料号的数量进行求和计算。传统实现方式通常需要编写脚本代码&#xff0c;增加了开…

LBE-LEX系列工业语音播放器|预警播报器|喇叭蜂鸣器的上位机配置操作说明

LBE-LEX系列工业语音播放器|预警播报器|喇叭蜂鸣器专为工业环境精心打造&#xff0c;完美适配AGV和无人叉车。同时&#xff0c;集成以太网与语音合成技术&#xff0c;为各类高级系统&#xff08;如MES、调度系统、库位管理、立库等&#xff09;提供高效便捷的语音交互体验。 L…

(LeetCode 每日一题) 3442. 奇偶频次间的最大差值 I (哈希、字符串)

题目&#xff1a;3442. 奇偶频次间的最大差值 I 思路 &#xff1a;哈希&#xff0c;时间复杂度0(n)。 用哈希表来记录每个字符串中字符的分布情况&#xff0c;哈希表这里用数组即可实现。 C版本&#xff1a; class Solution { public:int maxDifference(string s) {int a[26]…

【大模型RAG】拍照搜题技术架构速览:三层管道、两级检索、兜底大模型

摘要 拍照搜题系统采用“三层管道&#xff08;多模态 OCR → 语义检索 → 答案渲染&#xff09;、两级检索&#xff08;倒排 BM25 向量 HNSW&#xff09;并以大语言模型兜底”的整体框架&#xff1a; 多模态 OCR 层 将题目图片经过超分、去噪、倾斜校正后&#xff0c;分别用…

【Axure高保真原型】引导弹窗

今天和大家中分享引导弹窗的原型模板&#xff0c;载入页面后&#xff0c;会显示引导弹窗&#xff0c;适用于引导用户使用页面&#xff0c;点击完成后&#xff0c;会显示下一个引导弹窗&#xff0c;直至最后一个引导弹窗完成后进入首页。具体效果可以点击下方视频观看或打开下方…

接口测试中缓存处理策略

在接口测试中&#xff0c;缓存处理策略是一个关键环节&#xff0c;直接影响测试结果的准确性和可靠性。合理的缓存处理策略能够确保测试环境的一致性&#xff0c;避免因缓存数据导致的测试偏差。以下是接口测试中常见的缓存处理策略及其详细说明&#xff1a; 一、缓存处理的核…

龙虎榜——20250610

上证指数放量收阴线&#xff0c;个股多数下跌&#xff0c;盘中受消息影响大幅波动。 深证指数放量收阴线形成顶分型&#xff0c;指数短线有调整的需求&#xff0c;大概需要一两天。 2025年6月10日龙虎榜行业方向分析 1. 金融科技 代表标的&#xff1a;御银股份、雄帝科技 驱动…

观成科技:隐蔽隧道工具Ligolo-ng加密流量分析

1.工具介绍 Ligolo-ng是一款由go编写的高效隧道工具&#xff0c;该工具基于TUN接口实现其功能&#xff0c;利用反向TCP/TLS连接建立一条隐蔽的通信信道&#xff0c;支持使用Let’s Encrypt自动生成证书。Ligolo-ng的通信隐蔽性体现在其支持多种连接方式&#xff0c;适应复杂网…

铭豹扩展坞 USB转网口 突然无法识别解决方法

当 USB 转网口扩展坞在一台笔记本上无法识别,但在其他电脑上正常工作时,问题通常出在笔记本自身或其与扩展坞的兼容性上。以下是系统化的定位思路和排查步骤,帮助你快速找到故障原因: 背景: 一个M-pard(铭豹)扩展坞的网卡突然无法识别了,扩展出来的三个USB接口正常。…

未来机器人的大脑:如何用神经网络模拟器实现更智能的决策?

编辑&#xff1a;陈萍萍的公主一点人工一点智能 未来机器人的大脑&#xff1a;如何用神经网络模拟器实现更智能的决策&#xff1f;RWM通过双自回归机制有效解决了复合误差、部分可观测性和随机动力学等关键挑战&#xff0c;在不依赖领域特定归纳偏见的条件下实现了卓越的预测准…

Linux应用开发之网络套接字编程(实例篇)

服务端与客户端单连接 服务端代码 #include <sys/socket.h> #include <sys/types.h> #include <netinet/in.h> #include <stdio.h> #include <stdlib.h> #include <string.h> #include <arpa/inet.h> #include <pthread.h> …

华为云AI开发平台ModelArts

华为云ModelArts&#xff1a;重塑AI开发流程的“智能引擎”与“创新加速器”&#xff01; 在人工智能浪潮席卷全球的2025年&#xff0c;企业拥抱AI的意愿空前高涨&#xff0c;但技术门槛高、流程复杂、资源投入巨大的现实&#xff0c;却让许多创新构想止步于实验室。数据科学家…

深度学习在微纳光子学中的应用

深度学习在微纳光子学中的主要应用方向 深度学习与微纳光子学的结合主要集中在以下几个方向&#xff1a; 逆向设计 通过神经网络快速预测微纳结构的光学响应&#xff0c;替代传统耗时的数值模拟方法。例如设计超表面、光子晶体等结构。 特征提取与优化 从复杂的光学数据中自…