RocketMQ 里之前的延时消息未到时间是这样写的
ScheduleMessageService.this.timer.schedule(
new DeliverDelayedMessageTimerTask(this.delayLevel, nextOffset),
countdown);
现在变成了scheduleNextTimerTask(nextOffset, DELAY_FOR_A_WHILE);
这样会不会有延时呢?
是的,使用新的scheduleNextTimerTask
方法可以确保消息得到正确的延时处理。在旧的方法中,使用了countdown
参数来控制延时时间,而在新的方法中,使用了DELAY_FOR_A_WHILE
常量作为延时时间。
通过这种方式,RocketMQ会将消息发送到指定的延迟级别(this.delayLevel
),并使用nextOffset
作为下一次调度的时间戳。如果当前时间超过了DELAY_FOR_A_WHILE
所设定的延时时间,那么消息将会被立即发送出去。否则,消息将会在下一次调度时被发送出去。
因此,使用新的scheduleNextTimerTask
方法可以确保消息得到正确的延时处理,并且能够避免因为countdown
参数设置不当而导致的消息丢失问题。
版权声明:本文内容由阿里云实名注册用户自发贡献,版权归原作者所有,阿里云开发者社区不拥有其著作权,亦不承担相应法律责任。具体规则请查看《阿里云开发者社区用户服务协议》和《阿里云开发者社区知识产权保护指引》。如果您发现本社区中有涉嫌抄袭的内容,填写侵权投诉表单进行举报,一经查实,本社区将立刻删除涉嫌侵权内容。
涵盖 RocketMQ、Kafka、RabbitMQ、MQTT、轻量消息队列(原MNS) 的消息队列产品体系,全系产品 Serverless 化。RocketMQ 一站式学习:https://rocketmq.io/