开发者社区 > 云原生 > 云消息队列 > 正文

RocketMQ 里之前的延时消息未到时间是这样写的这样会不会有延时呢?

RocketMQ 里之前的延时消息未到时间是这样写的
ScheduleMessageService.this.timer.schedule(
new DeliverDelayedMessageTimerTask(this.delayLevel, nextOffset),
countdown);
现在变成了scheduleNextTimerTask(nextOffset, DELAY_FOR_A_WHILE);
这样会不会有延时呢?

展开
收起
小小鹿鹿鹿 2024-01-17 23:12:21 73 0
1 条回答
写回答
取消 提交回答
  • 面对过去,不要迷离;面对未来,不必彷徨;活在今天,你只要把自己完全展示给别人看。

    是的,使用新的scheduleNextTimerTask方法可以确保消息得到正确的延时处理。在旧的方法中,使用了countdown参数来控制延时时间,而在新的方法中,使用了DELAY_FOR_A_WHILE常量作为延时时间。

    通过这种方式,RocketMQ会将消息发送到指定的延迟级别(this.delayLevel),并使用nextOffset作为下一次调度的时间戳。如果当前时间超过了DELAY_FOR_A_WHILE所设定的延时时间,那么消息将会被立即发送出去。否则,消息将会在下一次调度时被发送出去。

    因此,使用新的scheduleNextTimerTask方法可以确保消息得到正确的延时处理,并且能够避免因为countdown参数设置不当而导致的消息丢失问题。

    2024-01-18 12:47:59
    赞同 展开评论 打赏

涵盖 RocketMQ、Kafka、RabbitMQ、MQTT、轻量消息队列(原MNS) 的消息队列产品体系,全系产品 Serverless 化。RocketMQ 一站式学习:https://rocketmq.io/

相关产品

  • 云消息队列 MQ
  • 热门讨论

    热门文章

    相关电子书

    更多
    RocketMQ Client-GO 介绍 立即下载
    RocketMQ Prometheus Exporter 打造定制化 DevOps 平台 立即下载
    基于 RocketMQ Prometheus Exporter 打造定制化 DevOps 平台 立即下载