前两篇记录了RocketMq下载安装与启动、面板搭建与问题解决:
本篇记录用java项目访问消息队列,使用Springboot项目,创建一个项目rocket-demo,再创建两个module:producer、consumer,生产者发送一个简单的字符串,消费者接受并打印,一个很简单的例子。
为简单操作,两个module都以rocketmq-demo为父项目,依赖统一在rocketmq-demo的pom文件中引入。
在项目(rocketmq-demo)最外层pom中引入依赖:
<dependency>
<groupId>org.apache.rocketmqgroupId>
<artifactId>rocketmq-spring-boot-starterartifactId>
<version>2.2.2version>
dependency>
spring:
application:
name: producer
server:
port: 5125
rocketmq:
name-server: localhost:9876
producer:
group: zrk-producer
其中name-server为自己安装的rocketmq的name server访问地址
2、编写代码
@RequestMapping("name")
@RestController
public class NameController {
@Resource
private RocketMQTemplate rocketMQTemplate;
@GetMapping("send")
public String sendName(String name) {
rocketMQTemplate.convertAndSend("send-name", name);
return "发送成功:" + name;
}
}
注:(1)直接引入RocketMQTemplate进行访问 (2)"send-name"为topic名称
spring:
application:
name: consumer
server:
port: 5124
rocketmq:
name-server: localhost:9876
其中name-server为自己安装的rocketmq的name server访问地址
2、编写代码
@Slf4j
@Service
@RocketMQMessageListener(consumerGroup = "zrk-consumer", topic = "send-name")
public class NameListener implements RocketMQListener<String> {
@Override
public void onMessage(String s) {
log.info("收到名称:{}", s);
}
}
注:(1)consumerGroup必须设置,否则报错 (2) topic必须与生产者保持一致
postman访问:
打开面板->消息->选择topic:send-name->点击搜索:
点击MESSAGE DETAIL
看到打印出日志
再看消息队列信息详情:
可以看到状态为已被消费