springboot整合rocketmq

springboot整合rocketmq

win系统安装环境

下载rocketmq

rocketmq下载官网
在这里插入图片描述

将下载好的压缩包进行解压,解压完后打开文件夹在这里插入图片描述
,进入到bin文件夹里面在这里插入图片描述

打开cmd窗口,执行一下两条命令

start mqnamesrv

start mqbroker -n 127.0.0.1:9876 autoCreateTopicEnable=true

执行命令启动完成后如下图所示,执行若报错,检查一下jdk版本还有环境都好着没,文件路径上尽量避免中文以及空格,具体原因需具体分析
在这里插入图片描述

在这里插入图片描述

引入依赖

<dependency>
 <groupId>org.apache.rocketmq</groupId>
 <artifactId>rocketmq-spring-boot-starter</artifactId>
 <version>2.2.2</version>
</dependency>

添加配置

在application.yml文件中添加配置

rocketmq:
name-server: 127.0.0.1:9876
consumer:
 group: my_consumer_group
producer:
 # 发送同一类消息的设置为同一个group,保证唯一
 group: my_producer_group
 # 发送消息超时时间,默认3000
 sendMessageTimeout: 10000
 # 发送消息失败重试次数,默认2
 retryTimesWhenSendFailed: 2
 # 异步消息重试此处,默认2
 retryTimesWhenSendAsyncFailed: 2
 # 消息最大长度,默认1024 * 1024 * 4(默认4M)
 maxMessageSize: 4096
 # 压缩消息阈值,默认4k(1024 * 4)
 compressMessageBodyThreshold: 4096
 # 是否在内部发送失败时重试另一个broker,默认false
 retryNextServer: false

生产者

import com.alibaba.fastjson2.JSONObject;
import org.apache.rocketmq.spring.core.RocketMQTemplate;
import org.apache.rocketmq.client.producer.SendCallback;
import org.apache.rocketmq.client.producer.SendResult;

@Component
public class RocketmqService {

    @Autowired
    private RocketMQTemplate rocketMQTemplate;

    @Async
    @PostConstruct
    public void init() {
        new Thread(() -> {
            Thread thread = Thread.currentThread();
            while (true) {
                synchronized (thread) {
                    try {
                        JSONObject jsonObject = new JSONObject();
                        jsonObject.put("time", System.currentTimeMillis());
                        rocketMQTemplate.asyncSend("time", jsonObject, new SendCallback() {
                            @Override
                            public void onSuccess(SendResult sendResult) {
                                System.out.println("send message success...");
                            }

                            @Override
                            public void onException(Throwable throwable) {
                                System.err.println("send message error..." + throwable);
                            }
                        });
                        thread.wait(2000);
                    } catch (InterruptedException e) {
                        throw new RuntimeException(e);
                    }
                }
            }
        }, "test").start();
    }
}

消费者

import com.alibaba.fastjson2.JSONObject;
import lombok.extern.slf4j.Slf4j;
import org.apache.rocketmq.spring.annotation.RocketMQMessageListener;
import org.apache.rocketmq.spring.core.RocketMQListener;
import org.springframework.stereotype.Component;

@Slf4j
@Component
@RocketMQMessageListener(topic = "time", consumerGroup = "my_consumer_group")
public class RocketmqListener implements RocketMQListener<JSONObject> {

    @Override
    public void onMessage(JSONObject message) {
        log.debug("message--->{}", message);
    }
}
  • 4
    点赞
  • 10
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
Spring Boot是一个用于构建独立的、基于生产的Java应用程序的框架,而RocketMQ是一个开源的分布式消息队列。将Spring Boot整合RocketMQ可以实现在应用程序中使用RocketMQ进行消息的发送和接收。 要在Spring Boot整合RocketMQ,首先需要在pom.xml文件中添加RocketMQ的依赖。可以使用如下代码添加依赖: ```xml <dependency> <groupId>org.apache.rocketmq</groupId> <artifactId>rocketmq-spring-boot-starter</artifactId> <version>${rocketmq.version}</version> </dependency> ``` 其中,`${rocketmq.version}`是RocketMQ的版本号,可以根据实际情况进行设置。接下来,需要在application.yml配置文件中进行相关配置,包括RocketMQ的地址、消费者和生产者的配置等。 在代码中,可以使用`@RocketMQMessageListener`注解来标记RocketMQ的消息监听器,使用`@RocketMQListener`注解来指定监听的消息主题和标签。同时,也可以使用`@Slf4j`注解来引入日志记录器。 然后,可以创建相应的消费者和生产者服务类,分别实现RocketMQ的消费者和生产者接口。消费者服务类需要实现`RocketMQListener`接口,并实现其`onMessage`方法来处理接收到的消息。生产者服务类可以使用RocketMQ的`RocketMQTemplate`类来发送消息。 最后,可以在控制器中调用消费者和生产者的服务类来实现消息的发送和接收。 这样,就完成了Spring BootRocketMQ整合。通过整合,可以方便地在Spring Boot应用程序中使用RocketMQ进行消息的传递和处理。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* *2* *3* [RocketMQ整合SpringBoot](https://blog.csdn.net/weixin_47638656/article/details/113849725)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 100%"] [ .reference_list ]
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值