消费者订阅队列(Consume)时能够指定autoAck参数,当autoAck为false时,RabbitMQ会等消费者显式地回复确认信号后才从内存(或磁盘)移去消息(实质上是先打上删除标记,以后再删除)。当autoAck为true时会自动确认,而后删除消息。
当autoAck 参数置为 false ,对于 RabbitMQ 服务端而言 ,队列中的消息分红了两个部分:一部分是等待投递给消费者的消息;一部分是己经投递给消费者,可是尚未收到消费者确认
信号的消息。 若是 RabbitMQ 直没有收到消费者的确认信号,而且消费此消息的消费者己经
断开链接(断开链接是惟一标准,不会超时),则 RabbitMQ 会安排该消息从新进入队列,等待投递给下 个消费者,固然也有可
能仍是原来的那个消费者。安全
参考:RabbitMQ实战性能