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

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

展开
收起
小小鹿鹿鹿 2024-01-17 23:12:21 92 分享 版权
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-learning.com/

还有其他疑问?
咨询AI助理