SpringBoot整合RocketMQ

在这里插入图片描述
被人怀念时我们才算存在过

这几天天气真是不错呢 好难得

应用场景

管理后台需要有一个聊天记录查询的功能,项目中使用的网易云信IM作为即时通讯服务,但是网易云信提供的聊天记录API不太灵活,不能满足需求。因此计划使用其提供的消息抄送机制,将聊天记录数据保存的我们数据库里。接收抄送消息入库,是一个典型的高并发写操作,所以这里采用消息中间件RocketMQ来完成。

1.下载安装RocketMQ

当然要使用rocketMQ第一步肯定是要先搭建使用环境,启动服务。

Windows环境下安装RocketMQ

Linux安装RocketMQ

2.pom文件导入maven依赖

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

3.配置文件加入rocketMQ的相关配置

rocketMQ.name-server=localhost:9876
rocketMQ.producer.send-message-timeout=300000
rocketMQ.producer.group=xxx

4.实体类用于封装数据

/**
 * 聊天记录实体类,下面省略了set get tosting等方法,根据自己的业务设置字段
 */
public class ChatMessage {

    private Long chatId;

    private Integer type;

    private Long senderId;

    private Long receiverId;

    private String content;

    private Long sendTime;

    private String ip;

    private Integer messageType;
}

5.用一个Controller来模拟一个简单的消息生产者


import com.great.candy.bean.entity.ChatMessage;
import org.apache.rocketmq.spring.core.RocketMQTemplate;
import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RestController;

import javax.annotation.Resource;

@RestController
@RequestMapping("/rocketMQ")
public class RocketMQController {

    @Resource
    private RocketMQTemplate rocketMQTemplate;


    @GetMapping("/send")
    public String send() {
        ChatMessage chatMessage = new ChatMessage();
        chatMessage.setChatId(10000L);
        chatMessage.setIp("127.0.0.1");
        chatMessage.setContent("这是消息内容");
        chatMessage.setMessageType(1);
        chatMessage.setSenderId(1000003L);
        chatMessage.setReceiverId(1000001L);
      	//发送消息
        rocketMQTemplate.convertAndSend("chatMessage", chatMessage);
        System.out.println("我是生产者,我完成了数据的发送");
        return "OK";
    }
}

6.接收消息


import com.great.candy.bean.entity.ChatMessage;
import org.apache.rocketmq.spring.annotation.RocketMQMessageListener;
import org.apache.rocketmq.spring.core.RocketMQListener;
import org.springframework.stereotype.Component;

@Component
@RocketMQMessageListener(consumerGroup = "chat_message_consumer", topic = "chatMessage")
public class RocketMQConsumer implements RocketMQListener<ChatMessage> {

    @Override
    public void onMessage(ChatMessage chatMessage) {
        System.out.println("我是消费者,下面是我收到的数据");
        System.out.println(chatMessage);
    }

}

7.测试结果

最后我们请求这个/rocketMQ/send接口,看一下控制台打印的效果,是不是很简单呢 O(∩_∩)O

在这里插入图片描述

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 ]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值