您的位置:首页 > 教育 > 培训 > 编辑app用什么软件_国外上市网络公司排名_广告投放优化师_网络营销工具及其特点

编辑app用什么软件_国外上市网络公司排名_广告投放优化师_网络营销工具及其特点

2025/1/7 22:23:36 来源:https://blog.csdn.net/p23gjj/article/details/144947556  浏览:    关键词:编辑app用什么软件_国外上市网络公司排名_广告投放优化师_网络营销工具及其特点
编辑app用什么软件_国外上市网络公司排名_广告投放优化师_网络营销工具及其特点

1. 介绍

一般情况下,RabbitMQ会将接收到的信息保存在内存中以降低消息收发的延迟。

但在某些特殊情况下,这会导致消息积压,比如:

  • 消费者宕机或出现网络故障

  • 消息发送量激增,超过了消费者处理速度

  • 消费者处理业务发生阻塞

一旦出现消息堆积问题,RabbitMQ内存占用就会越来越高,直到触发内存预警上限

为了解决这个问题,从RabbitMQ的3.6.0版本开始,就增加了Lazy Queues的模式,也就是惰性队列。惰性队列的特征如下:

  • 接收到消息后直接存入磁盘而非内存

  • 消费者要消费消息时才会从磁盘中读取并加载到内存(也就是懒加载

  • 支持数百万条的消息存储

官方推荐升级MQ为3.12版本或者所有队列都设置为LazyQueue模式


2. 控制台配置Lazy模式

在添加队列的时候,添加x-queue-mod=lazy参数即可设置队列为Lazy模式:

测试看一下效果:

 


3. 代码配置Lazy模式 

3.1 使用Bean声明

写一个配置类,使用QueueBuilder创建lazy.queue队列,并开启Lazy模式


代码如下:

package com.itheima.consumer.config;import org.springframework.amqp.core.Queue;
import org.springframework.amqp.core.QueueBuilder;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;@Configuration
public class LazyConfigUration {@Beanpublic Queue lazyQueue() {return QueueBuilder.durable("lazy.queue").lazy() // 开启Lazy模式.build();}
}

测试效果:

 

 


 3.2  基于注解声明

代码如下:

@RabbitListener(queuesToDeclare = @Queue(name = "lazy.queue",durable = "true",arguments = @Argument(name = "x-queue-mode", value = "lazy")
))
public void listenLazyQueue(String msg){log.info("接收到 lazy.queue的消息:{}", msg);
}

效果是一样的 

版权声明:

本网仅为发布的内容提供存储空间,不对发表、转载的内容提供任何形式的保证。凡本网注明“来源:XXX网络”的作品,均转载自其它媒体,著作权归作者所有,商业转载请联系作者获得授权,非商业转载请注明出处。

我们尊重并感谢每一位作者,均已注明文章来源和作者。如因作品内容、版权或其它问题,请及时与我们联系,联系邮箱:809451989@qq.com,投稿邮箱:809451989@qq.com