SpringBoot 整合RocketMQ

目录

一、引入依赖

二、配置文件

三、生产者

四、消费者

五、结果


一、引入依赖

XML 复制代码
<dependency>
    <groupId>org.apache.rocketmq</groupId>
    <artifactId>rocketmq-spring-boot-starter</artifactId>
    <version>2.2.0</version>
</dependency>

二、配置文件

XML 复制代码
#Rocketmq配置
rocketmq.name-server=192.168.11.99:9876
# 必须指定生产者组
rocketmq.producer.group=group01
# 消息发送超时时长,默认3s
rocketmq.producer.send-message-timeout=3000
# 同步发送消息失败重试次数,默认2
rocketmq.producer.retry-times-when-send-failed=3
# 异步发送消息失败重试次数,默认2
rocketmq.producer.retry-times-when-send-async-failed=3

三、生产者

java 复制代码
package com.beiyou.rocket.provider;

import lombok.extern.slf4j.Slf4j;
import org.apache.rocketmq.spring.core.RocketMQTemplate;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.messaging.Message;
import org.springframework.messaging.support.MessageBuilder;
import org.springframework.stereotype.Service;

@Service
@Slf4j
public class Provider1 {
    /**
     * 生产者
     */
    @Autowired
    private RocketMQTemplate rocketTemplate;

    public void send(String msg) {
        Message<String> build = MessageBuilder.withPayload(msg).build();
        // 发送消息
        rocketTemplate.convertAndSend("topic_01", build);
    }
}

四、消费者

java 复制代码
package com.beiyou.rocket.consumer;

import org.apache.rocketmq.spring.annotation.RocketMQMessageListener;
import org.apache.rocketmq.spring.core.RocketMQListener;
import org.springframework.stereotype.Component;

@Component
@RocketMQMessageListener(topic = "topic_01", consumerGroup = "group_205")
public class Consumer1 implements RocketMQListener<String> {

    @Override
    public void onMessage(String message) {
        System.out.println("消费者收到了消息: " + message);
    }
}

五、结果

六、.延迟消息

RocketMQ支持指定级别的延迟消息,即只能设置预设的几个时间等级的延迟,而不是任意时间延迟。目前RocketMQ社区版并不支持任意时间的精确延迟,RocketMQ在4.x版本只能够支持18种内置的延迟消息(1s 5s 10s 30s 1m 2m 3m 4m 5m 6m 7m 8m 9m 10m 20m 30m 1h 2h),具体实现方式是在发送消息时设置消息的延迟等级。

java 复制代码
  @Autowired
    private RocketMQTemplate rocketMQTemplate;

    public void sendMessage(String topic, String message) {
        Message<String> msg = MessageBuilder.withPayload(message).build();
        rocketMQTemplate.syncSend(topic,msg,3000,1);
        log.info("发送成功");
    }

七、死信队列

java 复制代码
@Service
@Slf4j
@RocketMQMessageListener(consumerGroup = "${rocketmq.consumer.group}", topic = "topic_01")
public class Consumer  implements RocketMQListener<String>, RocketMQPushConsumerLifecycleListener {
    @Override
    public void onMessage(String message) {
        System.out.println("Received message: " + message);
        log.info("Received message: " + message);;
        throw  new RuntimeException("test");
    }
    @Override
    public void prepareStart(DefaultMQPushConsumer consumer) {
        // 设置最大重试次数
        consumer.setMaxReconsumeTimes(2);
        // 如下,设置其它consumer相关属性
        consumer.setPullBatchSize(16);
    }
}
相关推荐
xiaoye20188 分钟前
Lettuce连接模型、命令执行、Pipeline 浅析
java
程序员爱钓鱼3 小时前
GoHTML解析利器:github.com/PuerkitoBio/goquery实战指南
后端·google·go
golang学习记3 小时前
从“大泥球“到模块化单体:Spring Modulith + IntelliJ IDEA 拯救你的代码
后端·intellij idea
颜酱3 小时前
一步步实现字符串计算器:从「转整数」到「带括号与优化」
javascript·后端·算法
离开地球表面_993 小时前
金三银四程序员跳槽指南:从简历到面试再到 Offer 的全流程准备
前端·后端·面试
UrbanJazzerati3 小时前
Scrapling入门指南:零基础也能学会的网页抓取神器
后端·面试
张洪权3 小时前
mysql + nest.js 加锁 搞并发问题
后端
郡杰3 小时前
MyBatisPlus
后端
beata3 小时前
Java基础-18:Java开发中的常用设计模式:深入解析与实战应用
java·后端
Qlly4 小时前
DDD 架构为什么适合 MCP Server 开发?
人工智能·后端·架构