当前位置: 首页 > news >正文

l临沂互助系统网站开发品牌高端网站制作官网

l临沂互助系统网站开发,品牌高端网站制作官网,品牌建设的最高境界是培育客户成为,大连网站建设优化#x1f389;#x1f389;欢迎光临#xff0c;终于等到你啦#x1f389;#x1f389; #x1f3c5;我是苏泽#xff0c;一位对技术充满热情的探索者和分享者。#x1f680;#x1f680; #x1f31f;持续更新的专栏《Spring 狂野之旅#xff1a;从入门到入魔》 欢迎光临终于等到你啦 我是苏泽一位对技术充满热情的探索者和分享者。 持续更新的专栏《Spring 狂野之旅从入门到入魔》 本专栏带你从Spring入门到入魔  这是苏泽的个人主页可以看到我其他的内容哦 努力的苏泽http://suzee.blog.csdn.net/ Spring Cloud Stream构建在SpringBoot之上提供了KafkaRabbitMQ等消息中间件的个性化配置引入了发布订阅、消费组和分区的语义概念  没学过消息中间件的可以看我之前的文章Kafka、RabbitMQ 下面是正片 按照自己的口味来食用哦有比较难懂的地方 目录 本文是通过大量阅读 和最近的一些项目的思考和总结 写出来的 关于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架构 消息驱动架构MDA 想象一下我们要建造一座房子。传统的方式是我们需要手工完成从设计到建造的每一个步骤。我们首先创建设计图纸然后按照图纸上的规格和要求一步步地建造房子。 而在MDA的方式下我们使用了一种自动化的工具来简化这个过程。我们首先创建一个高度抽象的模型就像是一个概念上的房子草图。这个模型与具体的实现技术无关只关注房子的整体结构和功能。 接下来我们使用工具将这个高级模型转换为与特定实现技术相关的模型就像是根据草图创建了一份针对具体施工工艺的图纸。例如我们可以将高级模型转换为使用钢筋混凝土结构的房子模型。 最后我们使用工具将这个特定实现技术的模型转换为实际的代码就像是根据图纸建造房子的过程。这些代码与应用技术密切相关最终实现了我们所设计的系统。 这种方式的好处是自动化工具帮助我们完成了从高级模型到具体代码的转换省去了手工操作的繁琐过程。这样开发人员可以更加清晰地理解整个系统的架构而不会受到具体实现技术的干扰。同时对于复杂的系统也减少了开发人员的工作量。 两者之间的关系 Spring Cloud Stream作为实现MDA的框架 他是怎么做的呢  我把他分成以下几点 定义平台无关模型PIM 在Spring Cloud Stream中你可以定义一个高度抽象的PIM它描述了消息的生产者和消费者之间的通信和交互方式而与具体的消息中间件实现无关。PIM可以包括消息的格式、结构、交换模式等。这个PIM可以作为系统设计的核心模型独立于具体的实现技术。 选择和配置绑定器Binder Spring Cloud Stream提供了与多种消息中间件集成的绑定器如Kafka、RabbitMQ等。绑定器可以将PIM与特定的消息中间件进行连接使得消息的发送和接收可以与具体的消息中间件实现进行交互。通过选择和配置适当的绑定器你可以将PIM转换为特定的平台相关模型PSM以便与消息中间件进行通信。 实现消息转换和处理 Spring Cloud Stream提供了消息转换的机制允许你定义如何将原始消息转换为特定的领域对象并在消费者之间传递。你可以使用消息转换器来处理消息的序列化和反序列化以及将消息转换为应用程序所需的数据结构。这样你可以在系统中实现解耦合和灵活的消息处理。 自动化生成代码 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-destinationorder-exchange 库存服务的配置文件application.properties spring.cloud.stream.bindings.receiveOrder-in-destinationorder-exchange 步骤 3: 实现消息转换和处理 在订单服务中定义一个消息发送接口并实现消息转换和发送逻辑。 EnableBinding(OrderSource.class) public class OrderService {Autowiredprivate 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 {Autowiredprivate 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 {Autowiredprivate 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云原生系列一起努力~
http://www.dnsts.com.cn/news/75711.html

相关文章:

  • 怎样自己动手做微官网站黄页网品种大全2021
  • 门户网站建设和管理情况wordpress 单栏 宽屏
  • 优门设 网站访问wordpress时失败
  • 大学生商品网站建设wordpress搭建视频站
  • 网站建设资金投入分析wordpress播放器样式
  • 做有后台的网站端州网站建设公司
  • 机场网站建设需求个人电脑做网站打不开数据库
  • 网络营销型网站建设的内容wordpress公告
  • 网站推广方案策划书赣楠脐橙网络营销推广方式
  • 做电商网站赚钱吗三亚市建设局网站公示
  • 城乡住房建设部网站造价师网亳州有做网站的吗
  • 招聘网站开发的目的与意义电商网站流程图
  • 公司网站的定义wordpress 最喜欢的主题
  • 建网站域名怎么买开发人员工具
  • 高端 旅游 网站建设怎样做jsp网站
  • 网站开发可选的方案有合肥大型网站设计
  • 同城网站视频推广一条多少钱
  • 阳高网站建设高端网站设计哪个好
  • 家居企业网站建设机构合肥网页设计哪家服务好
  • 神一般的网页设计网站潍坊最好的建设公司
  • 国外网站做淘宝客微信公众平台官网在哪里打开
  • 网站设计师简历怎样做机械租赁的网站
  • 建设新闻博客类网站要多大空间08 iis创建网站
  • 华西医院网站开发如何处理脓包痘痘
  • 在哪里找手机网站建设公司js 上传wordpress
  • 有创意的包装设计沈阳seo网站推广优化
  • 清远住房和城乡建设局网站福州建设人才网站
  • 建设工程168网站码支付wordpress前端
  • 网站打开速度太慢长春网站建设模板服务
  • 网站项目建设背景聊天室网站模板