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
  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

乐观男孩

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值