• SpringCloud Stream详解


    目录

    为什么需要SpringCloud Stream消息驱动呢?

    Binder

    案例

    消息驱动之生产者

    消息驱动之消费者

    分组消费与持久化

    为什么需要SpringCloud Stream消息驱动呢?

    比如说我们用到了RabbitMQ和Kafka,由于这两个消息中间件的架构上的不同,像RabbitMQ有exchange,kafka有Topic、partitions分区,这些中间件的差异性导致在实际项目开发中给我们造成了一定的困扰,我们如果用了两种消息队列的其中一种,后面的业务需求,如果我想往另外一种消息队列进行迁移,这无疑是灾难性的,一大堆东西都要重新推倒重新编写,因为它跟我们的系统耦合了,这时候SpringSloud Stream出场了!

    SpringCloud Stream是一个构建消息驱动微服务的框架,应用程序通过inputs或者 outputs来与SpringCloud Stream中的binder进行交互,我们可以通过配置来binding ,而 SpringCloud Stream 的binder负责与中间件交互,所以我们只需要搞清楚如何与Stream交互就可以很方便的使用消息驱动了!

    SpringCloud Stream由一个中间件中立的核组成,应用通过SpringCloud Stream插入的input(相当于消费者consumer,它是从队列中接收消息的)和output(相当于生产者producer,它是发送消息到队列中的)通道与外界交流

    通道通过指定中间件的Binder实现与外部代理连接,业务开发者不再关注具体消息中间件,只需关注Binder对应用程序提供的抽象概念来使用消息中间件实现业务即可!

    Binder

    Binder是SpringCloud Stream的一个抽象概念,是应用与消息中间件之间的粘合剂,目前SpringCloud Stream实现了Kafka和RabbitMQ的binder

    通过binder,可以很方便的连接中间件,可以动态的改变消息的destinations(对应于 Kafka的topic,RabbitMQ的exchanges),这些都可以通过外部配置项来做到,甚至可以任意的改变中间件的类型但是不需要修改一行代码

    案例

    消息驱动之生产者

    1.新建模块cloud-stream-rabbitmq-provider8801

    2.pom文件

    
        
        
            org.springframework.cloud
            spring-cloud-starter-stream-rabbit
        
        
        
            org.springframework.cloud
            spring-cloud-starter-netflix-eureka-client
        
        
            org.springframework.boot
            spring-boot-sta
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
  • 相关阅读:
    wireshark初步认识
    MySQL最大建议行数2000w, 靠谱吗?
    上周热点回顾(8.29-9.4)
    设计模式-组合模式
    Physics-infused Machine Learning for Crowd Simulation 论文理解
    squid反向代理
    C#读写应用程序配置文件App.exe.config,并在界面上显示
    前端node.js入门
    第 2 章 线性表(静态链表示例)
    UE4.27.2 源码使用 VS2022 编译时出现的错误的解决方法
  • 原文地址:https://blog.csdn.net/m0_61083409/article/details/126812152