当前位置: 代码网 > it编程>编程语言>Java > 【Spring云原生系列】SpringBoot+Spring Cloud Stream:消息驱动架构(MDA)解析,实现异步处理与解耦合

【Spring云原生系列】SpringBoot+Spring Cloud Stream:消息驱动架构(MDA)解析,实现异步处理与解耦合

2024年07月28日 Java 我要评论
Spring Cloud Stream是一个用于构建基于事件驱动的微服务应用程序的框架,其核心目标是简化开发过程,降低消息通信的复杂性,从而使开发人员能够专注于编写业务逻辑。Spring Cloud Stream通过提供Binder抽象,将应用程序与消息中间件解耦,让开发人员无需关心底层通信细节。同时,它还提供了一套丰富的API和特性,如消息分组、分区和错误处理,使得构建强大、可扩展的事件驱动应用程序变得更加简单。

f9c8a07d51874b7dbe2964ce27590fae.jpeg

🎉🎉欢迎光临,终于等到你啦🎉🎉

🏅我是苏泽,一位对技术充满热情的探索者和分享者。🚀🚀

🌟持续更新的专栏《spring 狂野之旅:从入门到入魔》 🚀

本专栏带你从spring入门到入魔 

这是苏泽的个人主页可以看到我其他的内容哦👇👇

 


 spring cloud stream构建在springboot之上,提供了kafka,rabbitmq等消息中间件的个性化配置,引入了发布订阅、消费组和分区的语义概念  没学过消息中间件的可以看我之前的文章kafkarabbitmq

下面是正片 按照自己的口味来食用哦(有比较难懂的地方)

目录

本文是通过大量阅读 和最近的一些项目的思考和总结 写出来的 关于spring cloud stream的文章不少  但我更想以观众能够轻松理解并且运用到自己的项目当中 我认为这才是技术存在的意义

spring cloud stream: 消息驱动架构

引言

spring cloud stream的概念和目标

 

事件驱动架构在现代微服务应用程序中的重要性

先来认识spring cloud stream架构

消息驱动架构(mda)

两者之间的关系

spring cloud stream作为实现mda的框架 他是怎么做的呢?  我把他分成以下几点:

那么我们了解了其思想和架构 我们要如何建立到我们自己的项目当中应用这种方式呢?  这是一个很关键的问题

实例讲解

步骤 1: 定义平台无关模型(pim)

步骤 2: 配置消息中间件绑定器

步骤 3: 实现消息转换和处理

步骤 4: 实现消息发送和接收的代码

步骤 5: 实现业务逻辑

以上就是一个很简单的mda框架的业务demo的实现啦 再结合中间件的知识学习加以实践 就能较好的构建一个云原生的项目啦

希望能够帮到有需要的读者 如有纰漏  望指出!

关注我 深入学习spring云原生系列!一起努力~ 


 

spring cloud stream: 消息驱动架构

引言

随着云计算、微服务和大数据技术的快速发展,构建可扩展、高性能和弹性的应用程序变得越来越重要。为了满足这些要求,许多开发人员转向了事件驱动架构,它允许应用程序通过基于事件的方式相互通信,从而提高了系统的响应速度和伸缩性。在这个背景下,spring cloud stream应运而生,它是一个用于构建基于事件驱动的微服务应用程序的框架,可以与现有的消息中间件(如apache kafka和rabbitmq)无缝集成。

spring cloud stream的概念和目标

spring cloud stream是一个用于构建基于事件驱动的微服务应用程序的框架,其核心目标是简化开发过程,降低消息通信的复杂性,从而使开发人员能够专注于编写业务逻辑。spring cloud stream通过提供binder抽象,将应用程序与消息中间件解耦,让开发人员无需关心底层通信细节。同时,它还提供了一套丰富的api和特性,如消息分组、分区和错误处理,使得构建强大、可扩展的事件驱动应用程序变得更加简单。

 

事件驱动架构在现代微服务应用程序中的重要性

事件驱动架构是指应用程序组件之间通过事件进行通信的架构。在这种架构中,组件之间的通信是异步的,基于发布-订阅模式,这有助于实现以下几个关键优势:

先来认识spring cloud stream架构

ae15dc5b347349eaa680f2f771ea13c3.png

 

消息驱动架构(mda)

8a5b823f12b347d5967b2e70d4d386a8.png

想象一下,我们要建造一座房子。传统的方式是,我们需要手工完成从设计到建造的每一个步骤。我们首先创建设计图纸,然后按照图纸上的规格和要求一步步地建造房子。

而在mda的方式下,我们使用了一种自动化的工具来简化这个过程。我们首先创建一个高度抽象的模型,就像是一个概念上的房子草图。这个模型与具体的实现技术无关,只关注房子的整体结构和功能。

接下来,我们使用工具将这个高级模型转换为与特定实现技术相关的模型,就像是根据草图创建了一份针对具体施工工艺的图纸。例如,我们可以将高级模型转换为使用钢筋混凝土结构的房子模型。

最后,我们使用工具将这个特定实现技术的模型转换为实际的代码,就像是根据图纸建造房子的过程。这些代码与应用技术密切相关,最终实现了我们所设计的系统。

这种方式的好处是,自动化工具帮助我们完成了从高级模型到具体代码的转换,省去了手工操作的繁琐过程。这样,开发人员可以更加清晰地理解整个系统的架构,而不会受到具体实现技术的干扰。同时,对于复杂的系统,也减少了开发人员的工作量。

50c430333a7f47acb698edb527a065b4.png

两者之间的关系

spring cloud stream作为实现mda的框架 他是怎么做的呢?  我把他分成以下几点:

  1. 定义平台无关模型(pim):
    在spring cloud stream中,你可以定义一个高度抽象的pim,它描述了消息的生产者和消费者之间的通信和交互方式,而与具体的消息中间件实现无关。pim可以包括消息的格式、结构、交换模式等。这个pim可以作为系统设计的核心模型,独立于具体的实现技术。

  2. 选择和配置绑定器(binder):
    spring cloud stream提供了与多种消息中间件集成的绑定器,如kafka、rabbitmq等。绑定器可以将pim与特定的消息中间件进行连接,使得消息的发送和接收可以与具体的消息中间件实现进行交互。通过选择和配置适当的绑定器,你可以将pim转换为特定的平台相关模型(psm),以便与消息中间件进行通信。

  3. 实现消息转换和处理:
    spring cloud stream提供了消息转换的机制,允许你定义如何将原始消息转换为特定的领域对象,并在消费者之间传递。你可以使用消息转换器来处理消息的序列化和反序列化,以及将消息转换为应用程序所需的数据结构。这样,你可以在系统中实现解耦合和灵活的消息处理。

  4. 自动化生成代码:
    spring cloud stream提供了自动化的代码生成能力,将psm转换为具体的代码实现。你只需要定义好pim和psm之间的映射关系,spring cloud stream会根据这些映射关系自动生成生产者和消费者的代码,从而实现消息的发送和接收。这样,你可以专注于定义pim和psm,并通过自动生成的代码实现实际的消息处理逻辑。

那么我们了解了其思想和架构 我们要如何建立到我们自己的项目当中应用这种方式呢?  这是一个很关键的问题

实例讲解

拿之前做过的一个商城系统来说,其中包含订单服务和库存服务之间的消息通信。订单服务负责接收订单创建请求并发送订单信息给库存服务,库存服务接收订单信息并更新库存。

步骤 1: 定义平台无关模型(pim)

在订单服务和库存服务之间定义一个平台无关模型,例如一个名为order的java类,表示订单信息。

public class order {
    private string orderid;
    private string productid;
    private int quantity;
    // 其他订单相关的属性和方法
    
    // getters and setters
}

步骤 2: 配置消息中间件绑定器

在订单服务和库存服务的配置文件中,配置spring cloud stream使用合适的消息中间件绑定器。在这个例子中,我们使用rabbitmq作为消息中间件。

订单服务的配置文件(application.properties):

spring.cloud.stream.bindings.sendorder-out-destination=order-exchange

库存服务的配置文件(application.properties):

spring.cloud.stream.bindings.receiveorder-in-destination=order-exchange

步骤 3: 实现消息转换和处理

在订单服务中,定义一个消息发送接口并实现消息转换和发送逻辑。

@enablebinding(ordersource.class)
public class orderservice {
    
    @autowired
    private ordersource ordersource;
    
    public void createorder(order order) {
        // 执行订单创建逻辑
        
        // 发送订单消息
        ordersource.sendorder().send(messagebuilder.withpayload(order).build());
    }
}

interface ordersource {
    @output("sendorder")
    messagechannel sendorder();
}

在库存服务中,定义一个消息接收接口并实现消息处理逻辑。

@enablebinding(ordersink.class)
public class inventoryservice {
    
    @streamlistener(target = "receiveorder")
    public void handleorder(order order) {
        // 执行库存更新逻辑
    }
}

interface ordersink {
    @input("receiveorder")
    subscribablechannel receiveorder();
}

步骤 4: 实现消息发送和接收的代码

在订单服务中,定义一个消息发送接口并实现消息发送逻辑。

@enablebinding(ordersource.class)
public class orderservice {
    
    @autowired
    private ordersource ordersource;
    
    public void createorder(order order) {
        // 执行订单创建逻辑
        
        // 发送订单消息
        ordersource.sendorder().send(messagebuilder.withpayload(order).build());
    }
}

interface ordersource {
    @output("sendorder")
    messagechannel sendorder();
}

在库存服务中,定义一个消息接收接口并实现消息处理逻辑。

@enablebinding(ordersink.class)
public class inventoryservice {
    
    @streamlistener(target = "receiveorder")
    public void handleorder(order order) {
        // 执行库存更新逻辑
    }
}

interface ordersink {
    @input("receiveorder")
    subscribablechannel receiveorder();
}

步骤 5: 实现业务逻辑

根据具体的业务需求,在订单服务和库存服务中编写业务逻辑来处理接收到的消息。例如,在库存服务中,你可以根据接收到的订单消息更新库存信息。

@enablebinding(ordersink.class)
public class inventoryservice {
    
    @autowired
    private inventoryrepository inventoryrepository;
    
    @streamlistener(target = "receiveorder")
    public void handleorder(order order) {
        // 根据订单消息更新库存信息
        string productid = order.getproductid();
        int quantity = order.getquantity();
        
        // 执行库存更新逻辑
        inventoryrepository.updateinventory(productid, quantity);
    }
}

以上就是一个很简单的mda框架的业务demo的实现啦 再结合中间件的知识学习加以实践 就能较好的构建一个云原生的项目啦


希望能够帮到有需要的读者 如有纰漏  望指出!

关注我 深入学习spring云原生系列!一起努力~ 

 

 

 

(0)

相关文章:

版权声明:本文内容由互联网用户贡献,该文观点仅代表作者本人。本站仅提供信息存储服务,不拥有所有权,不承担相关法律责任。 如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 2386932994@qq.com 举报,一经查实将立刻删除。

发表评论

验证码:
Copyright © 2017-2025  代码网 保留所有权利. 粤ICP备2024248653号
站长QQ:2386932994 | 联系邮箱:2386932994@qq.com