Spring Cloud Stream应用RocketMQ实例
pom
版本依赖查看
https://github.com/alibaba/spring-cloud-alibaba/releases
<?xml version="1.0" encoding="UTF-8"?>
<project xmlns="http://maven.apache.org/POM/4.0.0"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
<modelVersion>4.0.0</modelVersion>
<groupId>com.liu.springcloud.stream</groupId>
<artifactId>sc-stream-rocketmq-producer-test</artifactId>
<version>0.0.1</version>
<properties>
<maven.compiler.target>1.8</maven.compiler.target>
<maven.compiler.source>1.8</maven.compiler.source>
<spring.boot.version>2.6.3</spring.boot.version>
<spring.cloud.version>2021.0.1</spring.cloud.version>
<spring.cloud.alibaba.version>2021.0.1.0</spring.cloud.alibaba.version>
</properties>
<!--
引入 Spring Boot、Spring Cloud、Spring Cloud Alibaba 三者 BOM 文件,进行依赖版本的管理,防止不兼容。
在 https://dwz.cn/mcLIfNKt 文章中,Spring Cloud Alibaba 开发团队推荐了三者的依赖关系
-->
<dependencyManagement>
<dependencies>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-parent</artifactId>
<version>${spring.boot.version}</version>
<type>pom</type>
<scope>import</scope>
</dependency>
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-dependencies</artifactId>
<version>${spring.cloud.version}</version>
<type>pom</type>
<scope>import</scope>
</dependency>
<dependency>
<groupId>com.alibaba.cloud</groupId>
<artifactId>spring-cloud-alibaba-dependencies</artifactId>
<version>${spring.cloud.alibaba.version}</version>
<type>pom</type>
<scope>import</scope>
</dependency>
</dependencies>
</dependencyManagement>
<dependencies>
<!-- 引入 SpringMVC 相关依赖,并实现对其的自动配置 -->
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-web</artifactId>
</dependency>
<!-- 引入 Spring Cloud Alibaba Stream RocketMQ 相关依赖,将 RocketMQ 作为消息队列,并实现对其的自动配置 -->
<dependency>
<groupId>com.alibaba.cloud</groupId>
<artifactId>spring-cloud-starter-stream-rocketmq</artifactId>
</dependency>
</dependencies>
</project>
消息类准备
package com.liu.test.stream.rocketmq.producer.message;
/**
* 示例 01 的 Message 消息
*/
public class Demo01Message {
/**
* 编号
*/
private Integer id;
public Demo01Message setId(Integer id) {
this.id = id;
return this;
}
public Integer getId() {
return id;
}
@Override
public String toString() {
return "Demo01Message{" +
"id=" + id +
'}';
}
}
单topic
启动类
@SpringBootApplication
//已经过时 新版本
@EnableBinding({Source.class})
public class ProducerTest01Application {
public static void main(String[] args) {
SpringApplication.run(ProducerTest01Application.class, args);
}
}
配置文件
spring:
application:
name: stream-rocketmq-producer-application
cloud:
# Spring Cloud Stream 配置项,对应 BindingServiceProperties 类
stream:
# Binding 配置项,对应 BindingProperties Map
bindings:
output:
destination: topicA # 目的地。这里使用 RocketMQ Topic
content-type: application/json # 内容格式。这里使用 JSON
# erbadagang-input:
# destination: ERBADAGANG-TOPIC-01 # 目的地。这里使用 RocketMQ Topic
# content-type: application/json # 内容格式。这里使用 JSON
# group: test
# Spring Cloud Stream RocketMQ 配置项
rocketmq:
# RocketMQ Binder 配置项,对应 RocketMQBinderConfigurationProperties 类
binder:
name-server: 127.0.0.1:9876
#name-server: 10.199.47.152:9876;10.199.47.153:9876 集群
#accessKey: abcdef
#secretKey: 12345678
# RocketMQ 自定义 Binding 配置项,对应 RocketMQBindingProperties Map
bindings:
output:
# RocketMQ Producer 配置项,对应 RocketMQProducerProperties 类
producer:
group: test # 生产者分组
sync: true # 是否同步发送消息,默认为 false 异步。
server:
port: 18080
生产者
package com.liu.test.stream.rocketmq.producer.controller;
import com.liu.test.stream.rocketmq.producer.message.Demo01Message;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.cloud.stream.messaging.Source;
import org.springframework.messaging.Message;
import org.springframework.messaging.support.MessageBuilder;
import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RestController;
import java.util.Random;
@RestController
@RequestMapping("/test01")
//@EnableBinding({MySource.class})
public class Test01Controller {
private Logger logger = LoggerFactory.getLogger(getClass());
@Autowired private Source source;//<1>
@GetMapping("/send")
public boolean send() {
// <2>创建 Message
Integer a = new Random().nextInt();
Demo01Message message = new Demo01Message().setId(a);
// <3>创建 Spring Message 对象
Message<Demo01Message> springMessage = MessageBuilder.withPayload(message).build();
// <4>发送消息
logger.info("发送消息成功了:" + a);
return source.output().send(springMessage);
}
}
发送消息
2022-04-29 14:18:41.735 INFO 33972 — [io-18080-exec-4] c.l.t.s.r.p.controller.Test01Controller : 发送消息成功了:143564039
消费者
pom同生产者
配置文件
spring:
application:
name: erbadagang-consumer-application
cloud:
# Spring Cloud Stream 配置项,对应 BindingServiceProperties 类
stream:
# Binding 配置项,对应 BindingProperties Map
bindings:
input:
destination: topicA # 目的地。这里使用 RocketMQ Topic
content-type: application/json # 内容格式。这里使用 JSON
group: consumer-group-ERBADAGANG-TOPICA # 消费者分组,命名规则:组名+topic名
# Spring Cloud Stream RocketMQ 配置项
rocketmq:
# RocketMQ Binder 配置项,对应 RocketMQBinderConfigurationProperties 类
binder:
# name-server: 101.133.227.13:9876 # RocketMQ Namesrv 地址
name-server: 127.0.0.1:9876
# accessKey: contract
# secretKey: 12345678
#name-server: 10.199.47.152:9876;10.199.47.153:9876
#accessKey: contract
#secretKey: 12345678
# RocketMQ 自定义 Binding 配置项,对应 RocketMQBindingProperties Map
server:
# port: ${random.int[10000,19999]} # 随机端口,方便启动多个消费者
port: 9091 # 随机端口,方便启动多个消费者
启动类
package com.liu.test.stream.rocketmq.consumer;
import com.liu.test.stream.rocketmq.consumer.listener.MySink;
import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;
import org.springframework.cloud.stream.annotation.EnableBinding;
import org.springframework.cloud.stream.messaging.Sink;
@SpringBootApplication
@EnableBinding(Sink.class)
public class ConsumerTestApplication {
public static void main(String[] args) {
SpringApplication.run(ConsumerTestApplication.class, args);
}
}
消费者类
package com.liu.test.stream.rocketmq.consumer.listener;
import com.liu.test.stream.rocketmq.consumer.message.Demo01Message;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import org.springframework.cloud.stream.annotation.StreamListener;
import org.springframework.cloud.stream.messaging.Sink;
import org.springframework.messaging.handler.annotation.Payload;
import org.springframework.stereotype.Component;
@Component public class Demo01Consumer {
private Logger logger = LoggerFactory.getLogger(getClass());
@StreamListener(Sink.INPUT)
public void onMessage(@Payload Demo01Message message) {
logger.info("[onMessage][线程编号:{} 消息内容:{}]", Thread.currentThread().getId(), message);
}
}