前言
相信用过RocketMq的小伙伴都知道,RocketMq支持延时消息,通过设置指定的延时级别就可以让消息实现不同时效的延时功能,今天带大家了解的就是延时消息的原理~
如何实现延时?
在带大家正式了解RocketMq延时原理之前,先问大家一个问题,如果我们自己来实现延时功能,我们会如何实现?
- Sleep
经典永不过时,相信Sleep是我们最早接触的具有延时功能的函数,下面代码就可以简单实现延时5s后执行业务逻辑
java复制代码public static void main(String[] args) throws InterruptedException {
TimeUnit.SECONDS.sleep(5);
System.out.println("执行业务代码");
}
- Timer
Timer 类是在 JDK 1.3 版本中引入的。它位于 java.util 包中,用于支持简单的定时任务调度。
不过Timer也有着许多缺陷,谨慎使用~
java复制代码public static void main(String[] args) throws InterruptedException {
// schedule实现延时
Timer timer = new Timer();
timer.schedule(new TimerTask() {
@Override
public void run() {
System.out.println("执行业务逻辑");
}
}, 5000);
}
- ScheduledThreadPoolExecutor
ScheduledThreadPoolExecutor 类是在 JDK 1.5 版本中引入的。它是 ThreadPoolExecutor 类的子类,专门用于支持定时任务的调度和执行。
java复制代码public static void main(String[] args) throws InterruptedException {
ScheduledThreadPoolExecutor executor = new ScheduledThreadPoolExecutor(1);
// schedule实现延时
executor.schedule(() -> {
System.out.println("执行业务代码");
}, 5, TimeUnit.SECONDS);
}
- 时间轮
有关时间轮我就不细说了,在各大开源框架,诸如: Netty、Dubbo、Kafka都少不了它的影子
RocketMq如何实现的延时消息?
在上面带大家了解了常见的延时方案之后,我们再来探索RcketMq的延时原理~
RocketMq官方延时案例
下面是RocketMq官方提供的案例,我们可以看到代码中通过setDelayTimeLevel设定了延时级别,对应的延时时间就是10s
java复制代码package org.apache.rocketmq.example.schedule;
public class ScheduledMessageProducer {
public static final String PRODUCER_GROUP = "ExampleProducerGroup";
public static final String DEFAULT_NAMESRVADDR = "127.0.0.1:9876";
public static final String TOPIC = "TestTopic";
public static void main(String[] args) throws Exception {
DefaultMQProducer producer = new DefaultMQProducer(PRODUCER_GROUP);
producer.start();
int totalMessagesToSend = 100;
fo