【kafka系列】如何选择消息语义?

目录

业务权衡

如何选择消息语义?


业务权衡

|--------|------------------|-------------------|------------------|
| 维度 | At-Most-Once | At-Least-Once | Exactly-Once |
| 消息丢失风险 | 高 | 低 | 无 |
| 消息重复风险 | 无 | 高 | 无 |
| 网络开销 | 最低(无重试) | 中等(可能重试) | 最高(事务+协调) |
| 适用场景 | 可容忍丢失的实时数据流 | 不允许丢失的日志采集 | 金融交易、精准统计 |


如何选择消息语义?

  • At-Most-Once:优先性能与低延迟,接受数据丢失(如实时监控)。
  • At-Least-Once:优先可靠性,接受重复(需业务去重,如订单状态更新)。
  • Exactly-Once:强一致性场景(需Kafka事务+业务幂等性,如支付系统)。
相关推荐
七度黑光1 小时前
用 openclaw 给故障复盘打分:质量审核自动化实践
运维·服务器·前端·数据库·自动化
华科易迅2 小时前
Spring 事务(注解)
java·数据库·spring
Java面试题总结2 小时前
MySQL篇 索引失效
数据库·mysql
2501_933329552 小时前
企业舆情处置技术实践:基于AI的智能监测与申诉系统架构解析
人工智能·分布式·架构·系统架构
last demo2 小时前
mysql
运维·数据库·mysql·oracle
AI先驱体验官4 小时前
智能体变现:从技术实现到产品化的实践路径
大数据·人工智能·深度学习·重构·aigc
kevin_cat4 小时前
oracle 扩展表空间
数据库·oracle
花间相见4 小时前
【MySQL面试题】—— MySQL面试高频问题汇总:从原理到实战,覆盖90%考点
数据库·mysql·面试
高梦轩5 小时前
MySQL 数据库备份与恢复
数据库·oracle
一直都在5725 小时前
Redis(二)
数据库·redis·缓存