延迟队列存储的对象是对应的延迟消息,所谓的延迟消息是指当消息被发送以后,并不想让消费者立刻拿到消息,而是等待特定时间后,消费者才能拿到这个消息进行消费
(资料图片)
利用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 容器IDweb界面新建交换机选择类型出现红框标注即表示成功
@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是设给每条消息的。但是本质上,所有延时消息都还在一...
查看详情。
1、“有道”还可以。2、不过要把更新过的词库下载到我的电脑里面。3...
搜狐娱乐讯据韩国媒体报道,最近杂志《GQKorea》公开了和宋仲基进行...
欢迎观看本篇文章,小升来为大家解答以上问题。鉴别磷肥和钾肥的简...
请大佬推荐几款好玩的塔防手游吧(安卓)?第一名:部落冲突部落冲突...
桔乡再添新荣誉——融安县获评为2022年自治区级健康县
挖贝网2月22日,恩捷股份(证券代码:002812)控股股东云南恩捷新材...
2月21日,陈钰琪和《浮图缘》导演双双登上热搜,引发网友关注。《浮...
智通财经APP获悉,2月22日,受乘联会预测2月新能源车零售销量同比增...
无尽漫游怎么下载?想要比别人更加抢先抢快的玩到这款游戏,那么你...
近日,科技部和中国科学技术信息研究所发布了《国家创新型城市创新...
1、有大熊猫、金丝猴、牛羚、绿尾虹雉等11种国家一级重点保护动物,...
楼市也玩儿“空城计”?普爱思外汇看到最近有官媒发文说:要警惕新...
【手机中国新闻】2月21日,手机中国注意到,POCOC55在印度正式发布...
防范未然|槐荫公安开展反邪教宣传,邪教,公安,风清气正
人民网海口2月21日电(刘阳阳、刘瀚涛)近日,有群众在人民网“领导留...
星辰变第五季开播已经有一段时间了,而开播之时可以说一片群嘲声。...
以下是湖南海利在北京时间2月21日09:40分盘口异动快照:2月21日,湖...
近日,鞍山市中级人民法院出台《关于进一步依法保护民营企业和民营...
23武汉农商行CD014发布发行公告
2月12至18日,为期7天的云南省昆明市官渡区重点产业发展研修班在深...
据国星光电消息,国星光电817光耦器件新品上线,该系列产品可应用于...
2023阳山马拉松于2月22日重启报名,3月26日开跑,具体赛事规则未公...
2月20日以晴到多云为主受辐射降温和冷空气双重影响早晨的气温偏低市...
1、国产新能源汽车:汉、蔚来ES8、小鹏汽车P7、欧拉好猫、AionLX、...
1、抑郁症是指对日常活动(包括业余爱好和娱乐)兴趣显著减退;感到生...
零基础考初级会计自学方法:保持良好的心态和状态;多练习,在看考...
虽然减肥的过程也会很痛苦,但从她的状态来看,似乎更享受这种运动...
湖南宜章“非遗+旅游”以文化旅“闯”出旅游新业态