RockerMQ4.x 延时消息原理、流程梳理~

前言

相信用过RocketMq的小伙伴都知道,RocketMq支持延时消息,通过设置指定的延时级别就可以让消息实现不同时效的延时功能,今天带大家了解的就是延时消息的原理~


如何实现延时?

在带大家正式了解RocketMq延时原理之前,先问大家一个问题,如果我们自己来实现延时功能,我们会如何实现?

  1. Sleep

经典永不过时,相信Sleep是我们最早接触的具有延时功能的函数,下面代码就可以简单实现延时5s后执行业务逻辑

java复制代码public static void main(String[] args) throws InterruptedException {
   TimeUnit.SECONDS.sleep(5);

   System.out.println("执行业务代码");
}
  1. 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);

}
  1. 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);

}
  1. 时间轮

有关时间轮我就不细说了,在各大开源框架,诸如: 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
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值