消息队列的投递语义为何如此复杂:从「精确一次」的不可能到「有效一次」的工程实践
2019年,某支付平台因消息重复处理导致同一笔订单被扣款两次。工程师排查后发现,消费者在处理完消息后、发送确认前崩溃,消息队列在超时后重新投递,而业务代码没有实现幂等性。这不是个例——在分布式系统中,消息的重复投递几乎是不可避免的。 ...
2019年,某支付平台因消息重复处理导致同一笔订单被扣款两次。工程师排查后发现,消费者在处理完消息后、发送确认前崩溃,消息队列在超时后重新投递,而业务代码没有实现幂等性。这不是个例——在分布式系统中,消息的重复投递几乎是不可避免的。 ...
一个电商平台的订单系统收到两条消息:先是"订单已付款",紧接着是"订单已发货"。但消费者处理时,先处理了"已发货",再处理"已付款"。数据库里的订单状态变成了一个诡异的组合——用户明明已经付款,系统却显示发货在付款之前。 ...