RocketMQ使用延迟消息

Posted 乐观男孩

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了RocketMQ使用延迟消息相关的知识,希望对你有一定的参考价值。

说明

1、延时消息不是延迟发送,消息是实时发送的,只是消费者延迟消费
2、延迟消息主要通过对Message设置延迟级别实现,生产者和消费者按照正常逻辑进行生产和消费。

生产端

@Test
    public void sendMessage() throws Exception 
        DefaultMQProducer defaultMQProducer = RocketMqUtil.getDefaultMQProducer();
        Message message = new Message(RocketMqUtil.TOPIC, "schedule",
                "schedule-message".getBytes(Charset.forName("UTF-8")));
        //设置延迟级别,延迟级别≠延迟时间
        message.setDelayTimeLevel(5);
        SendResult sendResult = defaultMQProducer.send(message);
        log.info("发送消息结果:", sendResult.getSendStatus().name());
    

消费端

@Test
    public void consumer() throws Exception 
        DefaultMQPushConsumer defaultMQPushConsumer = RocketMqUtil.getDefaultMQPushConsumer();
        defaultMQPushConsumer.setConsumeFromWhere(ConsumeFromWhere.CONSUME_FROM_FIRST_OFFSET);
        defaultMQPushConsumer.subscribe(RocketMqUtil.TOPIC, "schedule");
        defaultMQPushConsumer.registerMessageListener(new MessageListenerConcurrently() 
            @Override
            public ConsumeConcurrentlyStatus consumeMessage(List<MessageExt> msgs, ConsumeConcurrentlyContext context) 
                for (MessageExt messageExt : msgs) 
                    log.info("出生时间:,存储时间:,当前时间:,消息内容:",
                            sdf.format(new Date(messageExt.getBornTimestamp())),
                            sdf.format(new Date(messageExt.getStoreTimestamp())),
                            sdf.format(new Date()),
                            new String(messageExt.getBody(), Charset.forName("UTF-8")));
                
                return ConsumeConcurrentlyStatus.CONSUME_SUCCESS;
            
        );
        defaultMQPushConsumer.start();
        Thread.sleep(30000L);
        defaultMQPushConsumer.shutdown();
    

运行结果示例


这里解释一下:
BornTimestamp:消息的出生时间,这是在客户端发送消息前设置(DefaultMQProducerImpl.sendKernelImpl)。
StoreTimestamp:消息的存储时间(并不是指服务端接收的时间),这是在服务端进行设置的(CommitLog.asyncPutMessage)。

从打印的结果可以看出,延迟时间是从BornTimestamp开始计算的,客户端发送消息很快,消息到达服务端后即返回。服务端在延迟指定时间后,消息才会被消费端看到。如果没有达到指定的时间,RocketMq-console也无法看到该消息。

延迟级别与延迟时间对应关系

延迟级别123456789101112131415161718
延迟时间1s5s10s30s1m2m3m4m5m6m7m8m9m10m20m30m1h2h

以上是关于RocketMQ使用延迟消息的主要内容,如果未能解决你的问题,请参考以下文章

RocketMQ使用延迟消息

五.RocketMQ极简入门-RocketMQ延迟消息

RocketMQ的延迟消息和顺序消息

RocketMQ源码(24)—DefaultMQPushConsumer延迟消息源码

RocketMQ系列广播与延迟消息

10 SpringBoot整合RocketMQ实现延迟消息