SpringCloudStream+RocketMQ多topic

之前写过两篇关于SpringCloudStream文章

spring-cloud-stream版本升级,告别旧注解@EnableBinding,拥抱函数式编程_spring-cloud-stream output注解没有了-CSDN博客

SpringCloudStream+RocketMQ事务消息配置_spring-cloud-starter-stream-rocketmq-CSDN博客

提到了一个多topic问题,在不配置spring.cloud.stream.function.definition的情况下只能配置一个in和一个out,这篇文章来解决这个问题。

根据上面的第一篇文章续写代码

一、续写生产者

1.写配置

在bindings后面添加即可,这里给出完整配置

复制代码
spring:
  application:
    name: provider
  cloud:
    nacos:
      discovery:
        server-addr: localhost:8848
        namespace: local
        username: nacos
        password: nacos
    stream:
      rocketmq:
        binder:
          name-server: 127.0.0.1:9876
      bindings:
        ## 新版本固定格式  channel名字-{out/in}-{index}
        addBounsChannel-out-0:
          destination: add-bouns
          group: bouns-producer-group
        secondChannel-out-0:
          destination: second
          group: second-producer-group
        source-out-0:
          destination: third
          group: third-producer-group
server:
  port: 8081

2.写代码

同样的使用streamBridge.send发消息

复制代码
public void sendMqSecondChannel() {
        streamBridge.send("secondChannel-out-0", "sendMqSecondChannel from Provider!");
    }

二、续写消费者

1.写配置

多个消费者时,需要在spring.cloud.stream.function.definition 定义bean名称,多个时用分号分隔

给出完整yaml代码

复制代码
spring:
  application:
    name: consumer
  cloud:
    nacos:
      discovery:
        server-addr: localhost:8848
        namespace: local
        username: nacos
        password: nacos
    stream:
      function:
        definition: addBounsChannel;secondChannel;source
      rocketmq:
        binder:
          name-server: 127.0.0.1:9876
      bindings:
        ## 新版本固定格式  channel名字-{out/in}-{index}
        addBounsChannel-in-0:
          destination: add-bouns
          group: bouns-consumer-group
        secondChannel-in-0:
          destination: second
          group: second-consumer-group
        source-in-0:
          destination: third
          group: third-consumer-group
server:
  port: 8082

2.写代码

跟之前一样,定义bean的Consumer

复制代码
   @Bean
    public Consumer<String> secondChannel() {
        return message -> {
            System.out.println("secondChannel消费消息:" + message);
        };
    }

三、常见问题

1.有Consumer必定会有Supplier,为什么不用Supplier发消息

Supplier也需要配置成@Bean,Supplier也跟Consumer一样用的监听模式,启动后不做处理会一直发,不如streamBridge.send发送灵活,这篇文章也有Supplier发送的例子可供参考Kafka Streams with Spring Cloud Stream - Spring Cloud

2.本文完整项目示例代码

【免费】springcloud-stream-rocketmq多topic示例代码资源-CSDN文库

相关推荐
Apache RocketMQ5 小时前
海量接入、毫秒响应:易易互联基于 Apache RocketMQ + MQTT 构筑高可用物联网消息中枢
物联网·rocketmq
庞轩px1 天前
第二篇:RocketMQ事务消息——分布式事务的最终一致性方案
分布式·rocketmq
庞轩px1 天前
第一篇:RocketMQ架构与核心概念——一条消息从生产到消费的完整旅程
架构·rocketmq
SuperherRo1 天前
服务攻防-处理平台安全&消息队列&ActiveMQ&RocketMQ&Kafka&Spring包&CVE复现
kafka·消息队列·rocketmq·activemq
YuanDaima20481 天前
WSL2 核心中间件部署实战:MySQL、Redis 与 RocketMQ
java·数据库·人工智能·redis·python·mysql·rocketmq
铁皮哥6 天前
【后端开发】RabbitMQ、RocketMQ、Kafka 怎么选?我从业务场景重新梳理了一遍
java·linux·数据库·分布式·kafka·rabbitmq·rocketmq
苍煜8 天前
RocketMQ系列第三篇:Java原生基础使用实操,手把手写生产者消费者Demo
java·rocketmq·java-rocketmq
苍煜8 天前
Kafka vs RocketMQ 生产环境选型指南
分布式·kafka·rocketmq
JWASX9 天前
【RocketMQ 生产者和消费者】- 事务源码分析(1)
java·rocketmq·java-rocketmq
_Evan_Yao9 天前
内存映射文件与零拷贝:Kafka、RocketMQ 飞升的秘密通道
分布式·kafka·rocketmq