ConcurrentDictionary 无法保证幂等性,因其不支持查-写-处理的原子操作且进程重启后丢失数据,必须结合 Redis 或数据库持久化去重,并设置合理过期时间。为什么 ConcurrentDictionary 加锁还不够用消息重复投递时,仅靠 ConcurrentDictionary 记录已处理的 messageId 很容易漏判------它不保证操作原子性,比如"查不存在 → 写入 → 处理业务"这三步之间仍有并发窗口。更糟的是,进程重启后内存态的字典就清空了,幂等直接失效。必须配合持久化存储(如 Redis 或数据库)做去重判断,ConcurrentDictionary 只能作本地缓存加速查+写必须是原子操作:Redis 用 SET key value NX EX,SQL 用带 WHERE NOT EXISTS 的插入或 INSERT ... ON CONFLICT DO NOTHING(PostgreSQL)注意过期时间设置:太短会导致误判重试消息为新消息;太长则占用存储,建议按业务重试窗口(如 15 分钟)+ 缓冲(如 5 分钟)设定IdempotentConsumer 类要不要自己封装自己写一个通用 IdempotentConsumer 类看似省事,但容易陷入"过度抽象"陷阱------不同消息源(Kafka、RabbitMQ、Azure Service Bus)的确认机制、重试语义、消息元数据结构差异很大,硬套同一接口反而增加出错概率。优先复用框架能力:如 MassTransit 的 IdempotentConsumerFilter、NServiceBus 的 MessageDrivenSubscription 自带幂等支持若必须自研,只封装"查重-执行-记录"骨架,把存储访问和消息提取逻辑交给调用方传入 Func,避免耦合具体中间件类型别在构造函数里初始化 Redis 连接或 DB context------它们不是线程安全的,应每次从工厂获取数据库唯一约束怎么设才不崩用 UNIQUE(message_id) 是最常用的兜底手段,但实际踩坑最多:字段长度超限、大小写敏感、NULL 值冲突、复合键遗漏业务维度,都会让约束失效或抛出意外异常。 稿定AI 拥有线稿上色优化、图片重绘、人物姿势检测、涂鸦完善等功能
相关推荐
爱喝水的鱼丶9 小时前
SAP-ABAP:数据类型与数据对象(8篇) 第七篇:进阶优化篇——基于类型与对象特征的性能优化技巧小白学大数据9 小时前
深度探索:Python 爬虫实现豆瓣音乐全站采集用户6757049885029 小时前
Celery 太重了?这可能是你一直在找的 asyncio 任务队列Cloud_Shy6189 小时前
Python 数据分析基础入门:《Excel Python:飞速搞定数据分析与处理》学习笔记系列(第十一章 Python 包跟踪器 下篇)程序员榴莲9 小时前
网络编程入门 Python Socket 实现一个简单的用户认证系统SelectDB技术团队9 小时前
PB 级自动驾驶数据秒级检索:Apache Doris 统一多模态数据平台实践知识分享小能手9 小时前
Flask入门学习教程,从入门到精通, 认识Flask路由 — 知识点详解 (2)AI棒棒牛9 小时前
YOLO26改进创新 | 全网首发!VECA弹性核心注意力重塑全局建模,线性复杂度增强检测骨干,嘎嘎创新!爱编程的小新☆10 小时前
LangGraph4j工作流框架DFT计算杂谈10 小时前
VASP新手入门: IVDW 色散修正参数