对于平常的业务而言,消息重复一般是不可避免的,我们只能在业务上来处理重复消息所带来的影响。
为了保证同一条消息无论被消费多少次,它的结果都是一样的,需要让消费者的处理逻辑具有幂等性。
为了实现幂等处理重复消息,可以给每条消息分配一个全局的唯一ID,当消费者接收消息时,先检查一下这个ID是否已经处理,如果已经处理则直接返回,如果没有处理,则执行逻辑并记录一下ID。
除了分配全局唯一ID,对于订单数据来说,还可以设计一个严格的状态流转(比如:待支付→已支付→待发货→已发货),这样在每次处理消息前对当前状态进行检查,看是否符合操作条件。