热门标签 | HotTags
当前位置:  开发笔记 > 后端 > 正文

rockemq发送延迟消息_RabbitMQ的延迟消息究竟是多少?

最近正好因为开发碰到了使用过程中发现,延迟消息没有效果,消息直接就被消费了的情况。因此就继续深入研究了一下问题原因,在此记录下来ÿ
35db0c540a2ab464f06b555d989a2e64.png

最近正好因为开发碰到了使用过程中发现,延迟消息没有效果,消息直接就被消费了的情况。因此就继续深入研究了一下问题原因,在此记录下来,给碰到类似问题的童鞋们参考。

问题定位

因为不是所有的消息都出现了没有延迟消息效果的因素,通过有问题的消息特征,大致猜测可能是延迟时间过长导致了消息延迟失败。为了验证这个原因,先拿之前文章中的例子,来测试一下延迟时间是否与问题直接相关。

对之前的延迟消息使用样例,接口做一下微改,增加了一个请求参数delay来控制延迟时间:

648cfcde333893c570ce3bcde083c0ef.png

然后尝试发起了两个请求:

请求1:延迟5000毫秒。消息发送到MQ之后确实延迟了5秒之后才得到了消费,没有任何问题。

f506d6b1bde5a8f8b3dde9997a18cb85.png

请求2:延迟1年(31536000000毫秒)。消息发送到MQ之后马上就被消费者消费了,完全没有延迟效果。

750509515f93a0a6c194c7776b4b9ef4.png

在明确了问题原因之后&#xff0c;需要对该功能的时候做一些明确的限定(延迟时间的极限)&#xff0c;以避免再次出现类似的问题。深入探索下去&#xff0c;这里的失败主要与消息的过期时间(TTL)有直接的关系。在RabbitMQ中&#xff0c;消息的过期时间必须是非负 32 位整数&#xff0c;即&#xff1a;0 <&#61; n <&#61; 2^32-1&#xff0c;以毫秒为单位。 其中&#xff0c;2^32-1 &#61; 4294967295。

这里我们可以尝试下面两个请求&#xff0c;分别设置延迟时间为4294967295何4294967296&#xff1a;

ce26082ebc120483cd2abc1f6f111a9a.png

可以发现&#xff0c;当延迟时间为4294967295毫秒的时候&#xff0c;延迟消息工作正常&#xff1b;当延迟时间为4294967296毫秒的时候&#xff0c;消息被直接消费&#xff0c;没有延迟效果。

所以&#xff0c;我们在使用RabbitMQ的延迟消息功能时候&#xff0c;必须注意它的延迟极限是4294967296毫秒。如果你的业务需求会超过这个临界值&#xff0c;就必须避开这个坑&#xff0c;采用其他方法来实现需要延迟或者定时执行的任务了。

如果你对此感兴趣&#xff0c;欢迎关注&#xff0c;收藏&#xff0c;转发&#xff01;学习上有问题的可以私信我或者加qun(630——455——594)获取资料

91245509372245f7ae3a74f4e55ecddc.png



推荐阅读
  • 本文总结了近年来在实际项目中使用消息中间件的经验和常见问题,旨在为Java初学者和中级开发者提供实用的参考。文章详细介绍了消息中间件在分布式系统中的作用,以及如何通过消息中间件实现高可用性和可扩展性。 ... [详细]
  • Spring Boot + RabbitMQ 消息确认机制详解
    本文详细介绍如何在 Spring Boot 项目中使用 RabbitMQ 的消息确认机制,包括消息发送确认和消息接收确认,帮助开发者解决在实际操作中可能遇到的问题。 ... [详细]
  • 可参照github代码:https:github.comrabbitmqrabbitmq-tutorialsblobmasterjavaEmitLogTopic.ja ... [详细]
  • RocketMQ在秒杀时的应用
    目录一、RocketMQ是什么二、broker和nameserver2.1Broker2.2NameServer三、MQ在秒杀场景下的应用3.1利用MQ进行异步操作3. ... [详细]
  • 修复一个 Bug 竟耗时两天?真的有那么复杂吗?
    修复一个 Bug 竟然耗费了两天时间?这背后究竟隐藏着怎样的复杂性?本文将深入探讨这个看似简单的 Bug 为何会如此棘手,从代码层面剖析问题根源,并分享解决过程中遇到的技术挑战和心得。 ... [详细]
  • 本文提供了 RabbitMQ 3.7 的快速上手指南,详细介绍了环境搭建、生产者和消费者的配置与使用。通过官方教程的指引,读者可以轻松完成初步测试和实践,快速掌握 RabbitMQ 的核心功能和基本操作。 ... [详细]
  • 在RabbitMQ中,消息发布者默认情况下不会接收到关于消息在Broker中状态的反馈,这可能导致消息丢失的问题。为了确保消息的可靠传输与投递,可以采用确认机制(如发布确认和事务模式)来验证消息是否成功抵达Broker,并采取相应的重试策略以提高系统的可靠性。此外,还可以配置消息持久化和镜像队列等高级功能,进一步增强消息的可靠性和高可用性。 ... [详细]
  • 顶尖编程语言,无可匹敌的选择
    我常常在想,一个人具备怎样的素质和能力,才称得上高级工程师?估计有不少人会说,“基础过硬、熟练掌握一门编程语言、至少看过一个 ... [详细]
  • 本文探讨了在一个物理隔离的环境中构建数据交换平台所面临的挑战,包括但不限于数据加密、传输监控及确保文件交换的安全性和可靠性。同时,作者结合自身项目经验,分享了项目规划、实施过程中的关键决策及其背后的思考。 ... [详细]
  • Windows环境下RabbitMQ安装详尽指南
    Windows环境下RabbitMQ安装详尽指南 ... [详细]
  • 在CentOS 7上部署WebRTC网关Janus
    在CentOS 7上部署WebRTC网关Janus ... [详细]
  • 在使用 RabbitMQ 构建延时队列的过程中,遇到了一些常见的问题。特别是在设置延时时,由于未充分考虑各种情况,导致延时时间被错误地设置为负数。这不仅会影响消息的正常处理,还可能引发系统异常。本文将深入分析这一问题的原因,并提供有效的解决方案,帮助开发者避免类似错误,确保延时队列的稳定性和可靠性。 ... [详细]
  • 如何查询与RabbitMQ连接的Celery任务数量及状态分析方法 ... [详细]
  • 在 CentOS 7 上部署和配置 RabbitMQ 消息队列系统时,首先需要安装 Erlang,因为 RabbitMQ 是基于 Erlang 语言开发的。具体步骤包括:安装必要的依赖项,下载 Erlang 源码包(可能需要一些时间,请耐心等待),解压源码包,解决可能出现的错误,验证安装是否成功,并将 Erlang 添加到环境变量中。接下来,下载 RabbitMQ 的 tar.xz 压缩包,并进行解压和安装。确保每一步都按顺序执行,以保证系统的稳定性和可靠性。 ... [详细]
  • SpringBoot非官方教程|终章:文章汇总springboot非官方教程,可能最接近于官方的一个教程,大多数案例都来自于官方文档,为了更好的理解,加入了个人的改造。码云下载:htt ... [详细]
author-avatar
大眼妹886
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有