一、如何保证消息被消费
RabbitMQ提供了消息补偿机制来保证消息被消费,当一条消费被发送后,到达队列后发给消费者。消费者消费成功后会给MQ服务器的队列发送一个确认消息,此时会有一个回调检测服务监听该接收确认消息的队列,然将消费的消息写入数据库。以上是消息成功被消费时的流程,此时如果消费者没有将消息消费,就不会给服务器发送确认消息了,生产者隔一段时间会延迟发送与之前发送的一模一样的数据到另一个给回调检测服务监听的队列,该服务收到延迟发送的消息后就会去数据库的消息表查询是否有该条消息,但是由于消费者没有消费成功给RabbitMQ服务器发送确认消息,所以数据库里并没有该消息,此时就会让生产者重新发送该消息。但是如果此时延迟消息发送也出了问题,也会触发重发该消息,因为此时会定时检查消费记录里的数据库与生产者发送消息的数据库进行比对,比对之后对未消费成功的消息会进行重发.