毕业设计网站建设题目,html5网页制作成品,嘉兴市住房和城乡建设局网站,创建网站的基本步骤一、导致重复消费的情况 1. 网络抖动。 2. 消费者挂了。 消费者消费消息后#xff0c;当确认消息还没有发送到MQ时#xff0c;就发生网络抖动或者消费者宕机。那当消费者恢复后#xff0c;由于MQ没有收到消息#xff0c;而且消费者有重试机制#xff0c;消费者就会再一次消…一、导致重复消费的情况 1. 网络抖动。 2. 消费者挂了。 消费者消费消息后当确认消息还没有发送到MQ时就发生网络抖动或者消费者宕机。那当消费者恢复后由于MQ没有收到消息而且消费者有重试机制消费者就会再一次消费这就会导致消息的重复消费。
二、如何解决 1. 每条消息设置一个唯一的标识id。 2. 幂等方案分布式锁、数据库锁悲观锁、乐观锁 。
三、面试题
面试官RabbitMQ消息的重复消费问题如何解决的
候选人嗯这个我们还真遇到过是这样的我们当时消费者是设置了自动确认机制当服务还没来得及给MQ确认的时候服务宕机了导致服务重启之后又消费了一次消息。这样就重复消费了。
因为我们当时处理的支付订单|业务唯一标识它有一个业务的唯一标识我们再处理消息时先到数据库查询一下这个数据是否存在如果不存在说明没有处理过这个时候就可以正常处理这个消息了。如果已经存在这个数据了就说明消息重复消费了我们就不需要再消费了。
面试官那你还知道其他的解决方案吗
候选人其实这个就是典型的幂等的问题比如redis分布式锁、数据库的锁都是可以的。