被人怀念时我们才算存在过
这几天天气真是不错呢 好难得
应用场景
管理后台需要有一个聊天记录查询的功能,项目中使用的网易云信IM作为即时通讯服务,但是网易云信提供的聊天记录API不太灵活,不能满足需求。因此计划使用其提供的消息抄送机制,将聊天记录数据保存的我们数据库里。接收抄送消息入库,是一个典型的高并发写操作,所以这里采用消息中间件RocketMQ来完成。
1.下载安装RocketMQ
当然要使用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