RabbitMq惰性队列

 

 

应用场景:

1.需要支持更多的消息存储

2.消费者由于各种各样的原因(如消费者下线、宕机或者由于维护而关闭等等)导致长时间不能消费消息而造成堆积时

 

重要概念:

1.惰性队列会尽可能地将消息存入磁盘中,消费者消费到对应的消息时才会被加载到内存中

2.惰性队列会将接受到的消息直接存入文件系统中,而不管是持久化的或者是非持久化的,这样可以减少了内存的消耗,但是会增加I/O的使用,如果消息是持久的,那么这样的I/O操作不可避免,惰性队列和持久化的消息可谓是“最佳拍档”.

3.如果惰性队列中存储的是非持久化的消息,内存的使用率会一直很稳定,但是重启之后消息一样会丢失.

4.惰性队列和普通队列相比

队列类型

发送消息量

每一个消息大小

消耗内存

惰性队列

一千万

1KB

1.5MB

普通队列

一千万

1KB

1.2GB

 

 

RabbitMQ 中的惰性队列是指当队列被声明时,它不会立即分配内存和处理其他资源,而是在需要时才进行分配。这种延迟分配的机制可以减少系统的资源消耗,尤其对于具有大量队列但只有少数活动的情况下更为有效。 当消息发送到一个惰性队列时,RabbitMQ 会根据需要进行内存分配和其他资源的处理。通过这种方式,RabbitMQ 可以有效地管理资源,只为实际需要处理的队列分配资源,而不是为所有队列预先分配资源。 惰性队列对于动态创建临时队列或者处理大量长时间闲置的队列非常有用。它可以帮助减少内存使用量,并提高整体系统的性能和可伸缩性。 要使用惰性队列,只需在声明队列时设置 `x-queue-mode` 参数为 `lazy` 即可。例如,使用 RabbitMQ 的 AMQP 客户端库声明一个惰性队列的示例如下: ```python import pika connection = pika.BlockingConnection(pika.ConnectionParameters('localhost')) channel = connection.channel() channel.queue_declare(queue='my_queue', arguments={'x-queue-mode': 'lazy'}) connection.close() ``` 在上述示例中,通过在声明队列时传递 `arguments` 参数,我们可以设置 `x-queue-mode` 参数的值为 `'lazy'`,以创建一个惰性队列。 需要注意的是,惰性队列可能会增加一些延迟,因为在消息被发送到队列后,RabbitMQ 需要进行资源分配和处理。因此,在设计应用程序时,需要谨慎考虑惰性队列的使用场景,以确保它们符合特定需求的性能要求。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值