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

工业上位机中企业微信推送(或其他网络调用,如 Modbus/OPC UA 读写、数据库写入、API 调用等)添加 Polly 重试机制的完整、实用实现方案

以下是针对工业上位机中企业微信推送或其他网络调用如 Modbus/OPC UA 读写、数据库写入、API 调用等添加Polly 重试机制的完整、实用实现方案。Polly 是 .NET 生态中最成熟、功能最强大的弹性与瞬时故障处理库在工业场景中特别适合处理网络抖动、PLC 短暂掉线、数据库连接超时、企业微信服务器偶发限流等情况。1. 安装 PollyNuGetPackageReferenceIncludePollyVersion8.*/!-- 核心库 --PackageReferenceIncludePolly.Extensions.HttpVersion8.*/!-- 如果使用 HttpClient --PackageReferenceIncludeMicrosoft.Extensions.Http.PollyVersion8.*/!-- DI 集成推荐 --2. Polly 重试策略推荐工业场景分类场景推荐策略组合最大重试次数等待时间策略触发条件StatusCode / 异常说明企业微信 Webhook 推送Retry WaitAndRetry Jitter3–5 次指数退避 JitterHttpRequestException、429、500–599避免触发频率限制Modbus TCP / OPC UA 读写Retry CircuitBreaker Timeout3 次线性/指数退避TimeoutException、SocketException、IOException典型网络/设备瞬时故障数据库批量写入Retry WaitAndRetry Bulkhead2–4 次固定 1–3s 或指数DbUpdateException、SqlException超时/死锁防止雪崩高可用关键指令下发Retry CircuitBreaker Fallback3 次指数退避所有异常 自定义业务失败码失败后执行备用方案如本地记录3. 推荐实现方式对比方式优点缺点推荐程度工业直接在方法中使用 Policy.ExecuteAsync最灵活、代码显式重复代码多★★★☆☆使用 HttpClientFactory Polly 扩展DI 友好、配置集中、全局统一只适用于 HttpClient 调用★★★★★自定义 PolicyWrap 扩展方法兼顾灵活与复用需维护扩展方法★★★★☆工业推荐HttpClientFactory Polly 扩展最符合 .NET 现代实践配置统一、易测试。4. 企业微信推送 Polly 重试完整示例方式一使用 HttpClientFactory Polly推荐Program.cs服务注册builder.Services.AddHttpClient(WeComWebhook,client{client.TimeoutTimeSpan.FromSeconds(10);}).AddPolicyHandler(GetWeComRetryPolicy()).AddPolicyHandler(GetCircuitBreakerPolicy());// 可选熔断Polly 策略定义可放在单独的 PolicyFactory 类中usingPolly;usingPolly.Extensions.Http;usingPolly.Contrib.WaitAndRetry;usingSystem.Net;privatestaticIAsyncPolicyHttpResponseMessageGetWeComRetryPolicy(){// 指数退避 Jitter抖动防止雪崩vardelayBackoff.DecorrelatedJitterBackoffV2(medianFirstRetryDelay:TimeSpan.FromMilliseconds(500),retryCount:4);// 总共尝试 5 次1 4returnHttpPolicyExtensions.HandleTransientHttpError()// 5xx 408 网络异常.OrResult(msgmsg.StatusCodeHttpStatusCode.TooManyRequests)// 429 限流.OrResult(msg!msg.IsSuccessStatusCode)// 其他非 2xx.WaitAndRetryAsync(delay,onRetry:(outcome,timespan,retryAttempt,context){Log.Warning(企业微信推送失败第 {Attempt} 次重试等待 {Delay}s - {Reason},retryAttempt,timespan.TotalSeconds,outcome.Exception?.Message??outcome.Result?.StatusCode.ToString());});}privatestaticIAsyncPolicyHttpResponseMessageGetCircuitBreakerPolicy(){returnHttpPolicyExtensions.HandleTransientHttpError().CircuitBreakerAsync(handledEventsAllowedBeforeBreaking:5,// 连续 5 次失败熔断durationOfBreak:TimeSpan.FromSeconds(30),// 熔断 30sonBreak:(outcome,breakDuration){Log.Error(企业微信推送熔断持续 {Break}s - {Reason},breakDuration.TotalSeconds,outcome.Exception?.Message??outcome.Result?.StatusCode.ToString());},onReset:()Log.Information(企业微信推送熔断恢复));}WeComWebhookNotifier 更新版使用注入的 HttpClientFactorypublicclassWeComWebhookNotifier{privatereadonlyIHttpClientFactory_httpClientFactory;privatereadonlystring_webhookUrl;publicWeComWebhookNotifier(IHttpClientFactoryhttpClientFactory,IConfigurationconfig){_httpClientFactoryhttpClientFactory;_webhookUrlconfig[WeCom:WebhookUrl]??thrownewInvalidOperationException(缺少 WebhookUrl 配置);}publicasyncTaskboolSendTextAsync(stringcontent,string[]?mentionedListnull){varclient_httpClientFactory.CreateClient(WeComWebhook);varpayloadnew{msgtypetext,textnew{content,mentioned_listmentionedList??Array.Emptystring()}};varjsonJsonSerializer.Serialize(payload);varcontentBodynewStringContent(json,Encoding.UTF8,application/json);try{varresponseawaitclient.PostAsync(_webhookUrl,contentBody);response.EnsureSuccessStatusCode();// Polly 已处理失败重试varresultawaitresponse.Content.ReadFromJsonAsyncWeComResponse();returnresult?.Errcode0;}catch(Exceptionex){Log.Error(ex,企业微信推送最终失败);returnfalse;}}}publicclassWeComResponse{publicintErrcode{get;set;}publicstringErrmsg{get;set;}string.Empty;}5. 其他场景的 Polly 扩展示例快速参考Modbus TCP 读取 重试varretryPolicyPolicy.HandleIOException().OrTimeoutException().OrModbusException().WaitAndRetryAsync(3,retryAttemptTimeSpan.FromSeconds(Math.Pow(2,retryAttempt)));varresultawaitretryPolicy.ExecuteAsync(async(){returnawait_modbus.ReadHoldingRegistersAsync(1,100,20);});数据库批量写入 熔断 回退varpolicyWrapPolicy.WrapAsync(Policy.HandleDbUpdateException().CircuitBreakerAsync(3,TimeSpan.FromSeconds(30)),Policy.HandleException().WaitAndRetryAsync(2,_TimeSpan.FromSeconds(2)),Policy.HandleException().FallbackAsync(async(){/* 本地 SQLite 缓存 */}));awaitpolicyWrap.ExecuteAsync(()_dbContext.BulkInsertAsync(points));6. 生产建议与注意事项日志记录每次重试方便事后分析网络/服务器问题熔断后告警熔断触发时额外推送到管理员配置化重试次数、等待时间、熔断阈值写入 appsettings.json测试用 Polly Chaos 工程注入故障延迟、抛异常验证策略效果指标监控用 App.Metrics / Prometheus 暴露重试次数、熔断状态如果需要更复杂的组合策略重试 熔断 限流 降级、Polly 在 BackgroundService 中的全局包装、与企业微信卡片消息结合的完整推送流程或者Polly Cache 降级方案直接告诉我我继续给出针对性代码。

相关文章:

工业上位机中企业微信推送(或其他网络调用,如 Modbus/OPC UA 读写、数据库写入、API 调用等)添加 Polly 重试机制的完整、实用实现方案

以下是针对工业上位机中企业微信推送(或其他网络调用,如 Modbus/OPC UA 读写、数据库写入、API 调用等)添加 Polly 重试机制 的完整、实用实现方案。 Polly 是 .NET 生态中最成熟、功能最强大的弹性与瞬时故障处理库,在工业场景中…...

用示波器调试STM32 PWM波形:CCR动态调整与占空比异常排查指南

STM32 PWM波形调试实战:从示波器诊断到动态调优全解析 当电机控制出现转速不稳或LED亮度闪烁时,多数问题都藏在PWM波形的细节里。上周调试一台3D打印机热床时,发现温度波动总比预期高5℃,最终在示波器上捕捉到PWM占空比周期性跳变…...

OpenClaw开源贡献:为ollama-QwQ-32B编写自定义技能指南

OpenClaw开源贡献:为ollama-QwQ-32B编写自定义技能指南 1. 为什么我们需要更多自定义技能 去年冬天,当我第一次尝试用OpenClaw自动整理电脑里散落的论文时,发现现有的技能库无法完美处理PDF批注提取和归类。这个痛点促使我开发了第一个自定…...

Nanbeige 4.1-3B快速上手:添加离线模式支持无网络环境下的本地推理

Nanbeige 4.1-3B快速上手:添加离线模式支持无网络环境下的本地推理 1. 项目介绍 Nanbeige 4.1-3B是一款具有独特像素游戏风格的大语言模型交互界面,专为本地化部署设计。这个项目将复古JRPG美学与现代AI技术完美结合,为用户带来沉浸式的对话…...

终极指南:如何为iCarousel编写高质量单元测试的5个关键技巧

终极指南:如何为iCarousel编写高质量单元测试的5个关键技巧 【免费下载链接】iCarousel A simple, highly customisable, data-driven 3D carousel for iOS and Mac OS 项目地址: https://gitcode.com/gh_mirrors/ic/iCarousel iCarousel是一个功能强大的iOS…...

LaTeX科技论文写作:LiuJuan20260223Zimage智能辅助工具开发

LaTeX科技论文写作:LiuJuan20260223Zimage智能辅助工具开发 告别繁琐的公式编辑和文献整理,让AI成为你的学术写作助手 1. 学术写作的痛点与解决方案 写科技论文的朋友都知道,LaTeX虽然排版精美,但学习曲线陡峭,操作繁…...

Agentic-doc终极速率限制指南:API调用频率控制与配额优化

Agentic-doc终极速率限制指南:API调用频率控制与配额优化 【免费下载链接】agentic-doc SDK for agentic document extraction and analysis 项目地址: https://gitcode.com/GitHub_Trending/ag/agentic-doc Agentic-doc是一个强大的Python库,专为…...

深度解析JARVIS:AI任务执行顺序与资源依赖优化算法

深度解析JARVIS:AI任务执行顺序与资源依赖优化算法 【免费下载链接】JARVIS JARVIS, a system to connect LLMs with ML community. Paper: https://arxiv.org/pdf/2303.17580.pdf 项目地址: https://gitcode.com/gh_mirrors/jarvis3/JARVIS JARVIS是一个连接…...

FXOS8700CQ驱动开发:FRDM-K64F六轴惯性传感实战

1. FXOS8700CQ驱动库技术解析:面向FRDM-K64F平台的高精度六轴惯性传感实现1.1 芯片特性与工程定位FXOS8700CQ是NXP(原Freescale)推出的集成式六轴惯性测量单元(IMU),在FRDM-K64F开发板上作为标准板载传感器…...

文脉定序保姆级教程:Mac M2/M3芯片本地部署BGE-Reranker-v2-m3

文脉定序保姆级教程:Mac M2/M3芯片本地部署BGE-Reranker-v2-m3 你是否遇到过这样的烦恼?用自己搭建的知识库或者搜索引擎提问,它确实返回了一堆结果,但最相关的答案往往不在最前面,你需要像淘金一样在一堆信息里费力筛…...

别再让BigDecimal的科学计数法坑你了!SpringBoot接口返回数据格式化实战

SpringBoot接口中BigDecimal科学计数法陷阱与工程化解决方案 在前后端分离的微服务架构中,数据格式的一致性往往成为联调阶段的"暗礁"。最近团队里一位中级开发工程师在支付模块上线后遇到了诡异的问题——前端显示的金额时而正常时而变成"1E7"…...

FlowState Lab 生成数据驱动艺术装置概念设计图集

FlowState Lab 生成数据驱动艺术装置概念设计图集 1. 数据艺术的新边界 当科技与艺术相遇,总能碰撞出令人惊叹的火花。FlowState Lab最近推出的一系列数据驱动艺术装置概念设计,正是这种跨界融合的绝佳体现。这些设计以前卫的艺术装置为载体&#xff0…...

Qwen3.5-9B镜像免配置:开箱即用的多模态大模型Web UI部署案例分享

Qwen3.5-9B镜像免配置:开箱即用的多模态大模型Web UI部署案例分享 1. 引言:为什么选择Qwen3.5-9B 在当今AI技术快速发展的时代,找到一个既强大又易于使用的多模态大模型并非易事。Qwen3.5-9B的出现改变了这一局面,它提供了开箱即…...

Qwen3-32B-Chat百度开发者学习资源包:含镜像离线下载、CLI工具、压力测试脚本

Qwen3-32B-Chat百度开发者学习资源包:含镜像离线下载、CLI工具、压力测试脚本 1. 镜像概述与核心特性 Qwen3-32B-Chat私有部署镜像专为RTX 4090D 24GB显存显卡深度优化,基于CUDA 12.4和驱动550.90.07构建,提供开箱即用的大模型推理环境。这…...

Qwen-Image镜像企业实操:用RTX4090D+Qwen-VL构建多模态客服图文问答系统

Qwen-Image镜像企业实操:用RTX4090DQwen-VL构建多模态客服图文问答系统 1. 项目背景与价值 在当今企业客服场景中,传统的纯文本问答系统已经难以满足用户需求。越来越多的客户倾向于通过图片、截图等方式提出问题,比如: 上传商…...

裸机级CAN FD调试不求人,手写C工具实现自动波特率探测、CRC校验绕过与仲裁段冲突定位,工程师私藏版

第一章:裸机级CAN FD调试工具的设计哲学与核心价值 裸机级CAN FD调试工具并非通用协议分析仪的简化版,而是面向嵌入式底层开发者的“数字听诊器”——它绕过操作系统抽象层,直接与CAN FD控制器寄存器交互,以微秒级时序精度捕获总线…...

Linux运维必备:用curl命令实现服务器健康检查的5种姿势

Linux运维实战:用curl构建高效服务器健康检查体系 引言 在分布式系统与微服务架构盛行的今天,服务器健康检查已成为运维工作的基础环节。传统的人工巡检方式早已无法满足现代IT环境的需求,而各类监控工具又往往存在部署复杂、资源占用高等问题…...

深入解析dupeguru内存碎片问题:使用内存池技术减少分配开销的完整指南

深入解析dupeguru内存碎片问题:使用内存池技术减少分配开销的完整指南 【免费下载链接】dupeguru Find duplicate files 项目地址: https://gitcode.com/gh_mirrors/du/dupeguru dupeguru是一款强大的跨平台重复文件查找工具,在处理大规模文件扫描…...

NFS服务端配置全流程:从端口开放到客户端挂载(解决RPC接收错误)

NFS服务端配置全流程:从端口开放到客户端挂载(解决RPC接收错误) 在分布式开发环境中,服务器间的文件共享是刚需。最近在配置NFS服务时,遇到了经典的RPC: Unable to receive错误,折腾半天才发现是端口配置的…...

【国密算法C语言性能优化白皮书】:20年密码学工程师亲授SM2/SM4/SM3三级加速实战(含AVX2+国密Bouncy Castle深度适配)

第一章:国密算法C语言性能优化全景概览国密算法(SM2/SM3/SM4)作为我国商用密码体系的核心,其在嵌入式设备、金融终端与物联网节点中的高效实现,直接关系到系统吞吐量、功耗与实时性。C语言因其贴近硬件、可控性强&…...

Vue3中的reactive转换:Naive Ui Admin普通对象响应式处理指南

Vue3中的reactive转换:Naive Ui Admin普通对象响应式处理指南 【免费下载链接】naive-ui-admin Naive Ui Admin 是一个基于 vue3,vite2,TypeScript 的中后台解决方案,它使用了最新的前端技术栈,并提炼了典型的业务模型,页面&#…...

实测PyTorch 2.9镜像:开箱即用GPU加速,AI开发效率提升50%

实测PyTorch 2.9镜像:开箱即用GPU加速,AI开发效率提升50% 你是不是也受够了这样的循环:新项目想用最新的PyTorch 2.9和CUDA 12.1,但手头的老项目还卡在PyTorch 1.x和CUDA 11.6上。每次切换项目,不是环境冲突就是驱动报…...

别再乱写CDC了!盘点Verilog代码中7个最常见的异步电路设计错误(附修复方案)

别再乱写CDC了!盘点Verilog代码中7个最常见的异步电路设计错误(附修复方案) 在数字IC设计中,跨时钟域(CDC)问题一直是工程师们最头疼的"隐形杀手"。据统计,超过30%的芯片功能异常都与…...

UEFI安全启动调试:EDK II中安全启动失败原因分析与解决方案

UEFI安全启动调试:EDK II中安全启动失败原因分析与解决方案 【免费下载链接】edk2 EDK II 项目地址: https://gitcode.com/gh_mirrors/ed/edk2 UEFI安全启动是现代计算机固件安全的核心机制,而EDK II作为UEFI固件开发的参考实现,其安全…...

Nanbeige 4.1-3B代码实例:st.markdown重写button/textarea的像素风格适配

Nanbeige 4.1-3B代码实例:st.markdown重写button/textarea的像素风格适配 1. 项目概述 Nanbeige 4.1-3B像素冒险聊天终端是一款专为对话模型设计的复古风格前端界面。这个项目通过重写Streamlit原生组件样式,实现了独特的JRPG像素游戏视觉效果。 核心…...

保姆级教程:在Windows和Ubuntu上配置Deeplearning4j环境(含Maven和Java安装)

跨平台深度学习开发环境搭建实战:Windows与Ubuntu下的Deeplearning4j配置指南 当Java开发者想要涉足深度学习领域时,Deeplearning4j(DL4J)无疑是最友好的入口之一。作为JVM生态中最成熟的深度学习框架,它让熟悉Java的开发者无需切换语言就能构…...

风储模型中的功率分配策略解析与优化策略探究

风储模型中,功率分配模型风电场的功率波动像个情绪不稳定的摇滚主唱——前一秒还激情四射,下一秒就突然断电。储能系统这时候就像个靠谱的调音师,得在后台疯狂调参数。今天咱们用Python撸个功率分配模型,看看怎么让这俩搭档别在电…...

ONLYOFFICE Docs监控告警升级流程:从警告到严重的响应指南

ONLYOFFICE Docs监控告警升级流程:从警告到严重的响应指南 【免费下载链接】DocumentServer ONLYOFFICE Docs is a free collaborative online office suite comprising viewers and editors for texts, spreadsheets and presentations, forms and PDF, fully comp…...

SSD1303 OLED驱动库深度解析:硬件设计、初始化与I²C/SPI工程实践

1. SSD1303 OLED显示驱动库深度解析与工程实践指南SSD1303是Solomon Systech(现为Synaptics)推出的单色OLED显示控制器,广泛应用于小尺寸、低功耗、高对比度的嵌入式显示模块中。与更常见的SSD1306相比,SSD1303支持更高分辨率&…...

华为华三设备CLI分页功能禁用全攻略:从临时关闭到永久配置

华为华三设备CLI分页功能深度优化指南 在设备运维的日常工作中,频繁查看长命令输出是每位工程师的必修课。当display current-configuration这样的命令返回数百行配置时,默认的分页机制反而成了效率的绊脚石——每次都需要手动按空格键继续,既…...