544
阿里云
消费幂等__最佳实践_消息队列 MQ-阿里云
本文档主要强调 MQ 消费者在接收到消息以后根据业务上的唯一 Key 对消息做幂等处理的必要性。
消费幂等的必要性
在互联网应用中,尤其在网络不稳定的情况下,MQ 的消息有可能会出现重复,这个重复简单可以概括为以下两种情况:
- 发送时消息重复【消息 Message ID 不同】:
MQ Producer 发送消息场景下,消息已成功发送到服务端并完成持久化,此时网络闪断或者客户端宕机导致服务端应答给客户端失败;如果此时 MQ Producer 意识到消息发送失败并尝试再次发送消息,MQ 消费者后续会收到两条内容相同但是 Message ID 不同的消息。
- 投递时消息重复【消息 Message ID 相同】;
MQ Consumer 消费消息场景下,消息已投递到消费者并完成业务处理,当客户端给服务端反馈应答的时候网络闪断,为了保证消息至少被消费一次,MQ 服务端将在网络恢复后再次尝试投递之前已被处理过的消息,MQ 消费者后续会收到两条内容相同并且 Message ID 也相同的消息。
处理建议
基于上述第一种原因,内容相同的消息 Message ID 可能会不同,真正安全的幂等处理,不建议以 Message ID 作为处理依据;最好的方式是以业务唯一标识作为幂等处理的关键依据,而业务的唯一标识可以通过 Key 设置到消息里面:
Message message = new Message();
message.setKey("ORDERID_100");
SendResult sendResult = producer.send(message);
订阅方收到消息时可以根据消息的 key 进行幂等处理:
consumer.subscribe("ons_test", "*", new MessageListener() {
public Action consume(Message message, ConsumeContext context) {
String key = message.getKey()
// 根据业务唯一标识的 key 做幂等处理
}
});
最后更新:2016-11-23 16:04:19
上一篇:
订阅关系一致__最佳实践_消息队列 MQ-阿里云
下一篇:
配置相关___常见问题_产品使用问题_消息队列 MQ-阿里云
资源监控__用户指南_CDN-阿里云
Android SDK手册__SDK手册_HTTPDNS-阿里云
按秒计费!阿里云服务器大升级
云服务器遭受网络攻击的处理方法__故障处理_云服务器 ECS-阿里云
查询模板分析作业__预置智能模版推荐接口_API使用手册_媒体转码-阿里云
管理对象生命周期__管理文件_开发人员指南_对象存储 OSS-阿里云
ECS 数据源 (2/3):Agent 安装__准备数据源_用户指南_业务实时监控服务 ARMS-阿里云
购买安骑士、安装安全狗被黑__用户指南_服务器安全(安骑士)-阿里云
计费模式__购买实例_购买指南_云服务器 ECS-阿里云
Discuz如何存储远程附件到OSS__ossftp_常用工具_对象存储 OSS-阿里云
相关内容
常见错误说明__附录_大数据计算服务-阿里云
发送短信接口__API使用手册_短信服务-阿里云
接口文档__Android_安全组件教程_移动安全-阿里云
运营商错误码(联通)__常见问题_短信服务-阿里云
设置短信模板__使用手册_短信服务-阿里云
OSS 权限问题及排查__常见错误及排除_最佳实践_对象存储 OSS-阿里云
消息通知__操作指南_批量计算-阿里云
设备端快速接入(MQTT)__快速开始_阿里云物联网套件-阿里云
查询API调用流量数据__API管理相关接口_API_API 网关-阿里云
使用STS访问__JavaScript-SDK_SDK 参考_对象存储 OSS-阿里云