SpringBoot 整合 RocketMQ
依赖
<dependency>
<groupId>org.apache.rocketmq</groupId>
<artifactId>rocketmq-spring-boot-starter</artifactId>
<version>2.2.0</version>
</dependency>
配置
rocketmq.name-server=127.0.0.1:9876
rocketmq.producer.group=my-producer-group
发送消息
@Autowired
private RocketMQTemplate rocketMQTemplate;
public void rocketMQTemplateTest(){
//topic -- 消息要发送的地址; body -- 具体的消息
String body = UUID.randomUUID().toString();
org.springframework.messaging.Message<String> message = MessageBuilder.withPayload(body)
.setHeader(RocketMQHeaders.TRANSACTION_ID, "MYKEY").build();
//发送消息
rocketMQTemplate.convertAndSend("mytopic",body);
//有回调的发送
rocketMQTemplate.asyncSend("mytopic", body, new SendCallback() {
@Override
public void onSuccess(SendResult sendResult) {
System.out.println("发送成功");
}
@Override
public void onException(Throwable throwable) {
System.out.println("发送成功");
}
});
}
接收消息
@Component
//可以${}的形式
@RocketMQMessageListener(topic = "mytopic", consumerGroup = "myconsumergroup", selectorExpression = "*")
//RocketMQListener -- 无返回,RocketMQReplyListener -- 有返回
public class SpringBootRocketmqConsumerService implements RocketMQReplyListener {
@Override
public Object onMessage(Object o) {
System.out.println(o.toString());
return "true";
}
}