c#如何实现幂等消费_c#幂等消费的几种常见用法

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 拥有线稿上色优化、图片重绘、人物姿势检测、涂鸦完善等功能

相关推荐
kexnjdcncnxjs1 小时前
Redis怎样实现Session的分布式共享
jvm·数据库·python
wx_xsooop1 小时前
iOS 审核 上架 被拒 4.3 【深度进阶】
python·编程·技术
tjc199010051 小时前
mysql如何防止SQL注入攻击_mysql参数化查询与转义
jvm·数据库·python
Kakaxiii1 小时前
【2026最新】Neo4j 数据库如何像 MySQL 一样导出和快速恢复完整数据
数据库·mysql·neo4j
盐烟1 小时前
xpath翻页爬取
python
sjsjsbbsbsn1 小时前
RAG 基础学习总结
java·数据库·学习
汽车仪器仪表相关领域1 小时前
Kvaser Memorator Light HS v2:单通道 CAN FD 便携记录仪,即插即用的故障诊断利器
运维·服务器·数据库·人工智能·功能测试·单元测试
Francek Chen1 小时前
【大数据存储与管理】NoSQL数据库:05 NoSQL的三大基石
大数据·数据库·分布式·nosql
人道领域2 小时前
【黑马点评日记】Redis分布式锁终极方案:Redisson全面解析(含源码解析)
java·数据库·redis·分布式·缓存