简述什么是RabbitMQ延迟队列 ?
RabbitMQ的延迟队列是一种存储延迟消息的队列。在这种队列中,消息在进入队列后并不会立即被消费者消费,而是需要等待一段时间后才能被消费。这种延迟消费的特性可以用来做定时任务,例如定时发送邮件、定时数据备份等。
RabbitMQ原生不支持延迟消息,但可以通过两种方式实现延迟队列:
- 使用死信交换机 + 消息TTL方案:将消息发送到死信交换机,并设置消息的TTL(Time To Live)属性,当消息在队列中等待时间超过TTL时,消息将被自动发送到指定的死信队列中。
- 使用rabbitmq-delayed-message-exchange插件:该插件可以扩展RabbitMQ的功能,支持延迟消息的发送。通过该插件,生产者可以将消息的延迟时间作为参数传递给RabbitMQ,RabbitMQ将在消息到达指定的延迟时间后将消息发送到指定的队列中。
延迟队列的优点是可以减少RAM中保存的消息数量,但会增加磁盘I/O次数。同时,由于队列中可能包含大量等待一段时间的消息,因此队列可能会变得很长。这种情况可能会在电商大促等短时间内需要处理大量消息的场景中出现。