目录
一、如何保证消息被消费
二、如何保证消息幂等性
一、如何保证消息被消费
RabbitMQ提供了消息补偿机制来保证消息被消费,当一条消费被发送后,到达队列后发给消费者。消费者消费成功后会给MQ服务器的队列发送一个确认消息,此时会有一个回调检测服务监听该接收确认消息的队列,然将消费的消息写入数据库。以上是消息成功被消费时的流程,此时如果消费者没有将消息消费,就不会给服务器发送确认消息了,生产者隔一段时间会延迟发送与之前发送的一模一样的数据到另一个给回调检测服务监听的队列,该服务收到延迟发送的消息后就会去数据库的消息表查询是否有该条消息,但是由于消费者没有消费成功给RabbitMQ服务器发送确认消息,所以数据库里并没有该消息,此时就会让生产者重新发送该消息。但是如果此时延迟消息发送也出了问题,也会触发重发该消息,因为此时会定时检查消费记录里的数据库与生产者发送消息的数据库进行比对,比对之后对未消费成功的消息会进行重发
二、如何保证消息幂等性
幂等性:指的是一次或多次请求某一个资源,对于资源本身一个具有相同的结果,也就是多次执行与一次执行对资源本身影响相同。我们通过使用数据库的乐观锁的方式保证消息的幂等性,也就是给消息加一个版本号,第一次消息进入消费者在入库时将版本号自增,后续相同的该消息被重复执行时,版本与数据库不一致该消息不能就被再次消费