延迟队列存储的对象是对应的延迟消息,所谓的延迟消息是指当消息被发送以后,并不想让消费者立刻拿到消息,而是等待特定时间后,消费者才能拿到这个消息进行消费
利用RabbitMq
的TTL
和死信队列 来实现延时消费。
(资料图)
如果设置的是队列统一过期时间放到死信队列,没有什么问题。
如果是延时时间设置到每条消息上的。而不是给队列的。
实现方式为消息存活时间为动态用户页面可配置的。
先用一条消息的存活时间是1天。后面又进了一条消息存活时间是1小时。
结果一小时到了,发现这条消息并没有被转发到消费延时过期消息的队列。
原因是尽管ttl是设给每条消息的。但是本质上,所有延时消息都还在一个队列里,对它过期时间的检测也是从头部开始的。
它不会检测每一条消息是否过期。而是顺序检测。
如果first in
的消息过期时间很长,会导致它阻塞后进的消息。
不仅无法实现真正的过期时间。还会导致,一个大的过期时间的先进的消息,会堆积一堆后进的过期时间短的消息。
这个时候可以使用rabbitMq的一个插件:rabbitmq_delayed_message_exchange
一段时间以来,人们一直在寻找用RabbitMQ实现延迟消息的传递方法,到目前为止,公认的解决方案是混合使用TTL和DLX。而rabbitmq_delayed_message_exchange插件就是基于此来实现的,RabbitMQ延迟消息插件新增了一种新的交换器类型,消息通过这种交换器路由就可以实现延迟发送
需要根据自己的rabbitMq选择对应的版本。我rabbitMq的版本是RabbitMQ 3.11.0
,对应的插件版本就是:3.11.1
--1、cd到rabbitmq默认安装位置cd /usr/lib/rabbitmq/lib/rabbitmq_server-3.7.18/plugins--2、通过ftp工具将插件上传到此目录下--3、开启插件rabbitmq-plugins enable rabbitmq_delayed_message_exchange--4、重启MQ服务systemctl restart rabbitmq-server
--1、通过ftp工具将插件上传到Linux服务器的根目录下--2、拷贝到docker中rabbitmq插件目录下,rabbitmq_delayed_message_exchange-3.9.0.ez(下载包的全名)docker cp /rabbitmq_delayed_message_exchange-3.9.0.ez 容器ID:/plugins--3、进入容器docker exec -it 容器id /bin/bash--4、查看插件是否存在(确保2中的操作已经将插件拷贝过来了)cd pluginsls |grep delay--5、开启插件rabbitmq-plugins enable rabbitmq_delayed_message_exchange--6、退出容器exit--7、重启MQ服务docker restart 容器ID
web界面新建交换机选择类型出现红框标注即表示成功
@Configurationpublic class DelayRabbitmqConfig { /** * 声明延迟队列 * @return */ @Bean public Queue delayQueue(){ return new Queue(QueueConstant.DelayQueue, true,false,false); } /** * 声明延迟自定义交换机类型 * @return */ @Bean public CustomExchange delayCustomExchange(){ HashMap args = new HashMap<>();// 设置 x-delayed-type 为 direct,当然也可以是 topic 等 发送消息时设置消息头 headers 的 x-delay 属性,即延迟时间,如果不设置消息将会立即投递 args.put("x-delayed-type","direct"); return new CustomExchange(ExchangeConstant.DelayCustomerExchange, "x-delayed-message",true,false,args); } /** * 绑定延迟交换机和队列 * @return */ @Bean public Binding delayQueueAndCustomExchange(){ return BindingBuilder.bind(delayQueue()) .to(delayCustomExchange()).with(RoutingKeyConstant.DelayCustomerRoutingKey).noargs(); }}
引入依赖: xmlns:util="http://www.springframework.org/schema/util" http://www.springframework.org/schema/util http://www.springframework.org/schema/util/spring-util-4.0.xsd
//消息发送final MessagePostProcessor messagePostProcessor = new MyMessagePostProcessor(Integer.valueOf(ttl.toString()));DisTimingPushDto disTimingPushDto = new DisTimingPushDto();disTimingPushDto.setOrderId(dispense.getOrderId());disTimingPushDto.setPushTime(disDispense.getPushTime());rabbitTemplate.convertAndSend(MsgQueueEnum.TIMING_PUSH.getExchangeName(), MsgQueueEnum.TIMING_PUSH.getQueueName(), disTimingPushDto, messagePostProcessor);//每条消息时间配置import org.springframework.amqp.AmqpException;import org.springframework.amqp.core.Message;import org.springframework.amqp.core.MessagePostProcessor;/** * 延迟消息处理器 Processor * @author king * @date 2022年12月28日 11:14 */public class MyMessagePostProcessor implements MessagePostProcessor { /** * 消息延迟时间,单位:毫秒 */ private final Integer TTL; public MyMessagePostProcessor(final Integer ttl) { this.TTL = ttl; } @Override public Message postProcessMessage(Message message) throws AmqpException { message.getMessageProperties().setDelay(TTL); return message; }}
原因是尽管ttl是设给每条消息的。但是本质上,所有延时消息都还在一...
2月24日,据媒体报道,美国国家法律和政策中心(NLPC)单独提交了一...
1、龙水湖地处川东平行岭谷与川中丘陵分界线上,故具有独特的自然景...
压价键重启:明日(2 28)14地猪价急转直下,下跌风暴再次掀起,山...
阳江社保缴纳比例表2022-2023年,2023年阳江社会保险缴费基数是多少...
1、你好:清华大学2、北京大学3、浙江大学4、复旦大学5、华中科技大...
智通财经APP获悉,太平洋航运(02343)现跌超7%,截至发稿,跌7 1%,...
1、微力,拼音是wēilì,汉语词语,意思是微小的能力,微薄的力量...
1、研究生复试是研究生考试制度的重要组成部分,即通过研究生入学考...
1、狗(拉丁文Canislupusfamiliaris)属于脊索动物门、脊椎动物亚门...
1、军工路位于上海市区东部,跨杨浦、宝山两区,南起平凉路,北过逸...
1、刘颖慧,女,副主任医师。2、1996年全日制临床医学本科毕业,从...
1、忍者是日本特有的一种特殊职业,“忍”即“隐”,有汉语词“隐忍...
1、狼牙破碎机(齿辊破碎机)狼牙破。2、狼牙破是参照美国岗拉克破碎...
未·LIVE—「曜·北斗」武汉站【当时未举办,延期】➤举办地点:武...
1、能提供什么服务?114,我们都知道,是一个电话查询系统,很多人可...
南都电源在接受调研时表示,公司锂电回收目前已经具备7万吨的处理能...
贵州金沙:乘势而上开新局夯实工业经济向好增长
原创苍穹米内网精彩内容中药领域利好不断!近日,国家药监局发文规...
第31分钟,米兰前场耐心组织进攻,中路分球至右路后,卡卢卢下底传...
正安凤仪街道特色养老服务暖人心品茗下棋、吟诗作画、抚琴鼓瑟……...
你需要的东西速干土堆肥水肥料竹子在院子里很受欢迎,也可以作为室...
河北省景县发布大风蓝色预警
丞相作为百官之首,无疑是古代历史上最重要的官职。在三国时期,曹...
1、胖的反义词是:瘦adj瘦;瘦;稀释例句用作形容词池塘上的冰太薄...
足协新赛季俱乐部准入通知截图。中新网电中国足协15日晚发布2023赛...
1、语出《晋书·谢安传》:“安虽受朝寄,然东山之志始末不渝,表示...
1、准备烧烤材料去烧烤之前先准备烧烤材料。去超市购买食材,当然,...
图片是指由图形、图像等构成的平面媒体。图片的格式很多,但总体上...
1、我觉得是做诠释。2、假如这句话是一个问题的回答,那么这个问题...