【设计模式】JAVA Design Patterns——Aggregator Microservices(聚合器微服务模式)

简介: 【设计模式】JAVA Design Patterns——Aggregator Microservices(聚合器微服务模式)

🔍目的


用户对聚合器服务进行一次调用,然后聚合器将调用每个相关的微服务。


🔍解释


真实世界例子

网络市场需要有关产品及其当前库存的信息。 它调用聚合服务,聚合服务依次调用产品信息微服务和产品库存微服务,返回组合信息。

通俗描述

聚合器微服务从各种微服务中收集数据,并返回一个聚合数据以进行处理。

维基百科

聚合器微服务调用多个服务以实现应用程序所需的功能。


程序示例

定义产品数据模型

public class Product {
  private String title;
  private int productInventories;
  // getters and setters ->
  ...
}


生成聚合器服务,包含用于调用相应微服务的客户端ProductInformationClient ProductInventoryClient

@RestController
public class Aggregator {
 
  @Resource
  private ProductInformationClient informationClient;
 
  @Resource
  private ProductInventoryClient inventoryClient;
 
  @RequestMapping(path = "/product", method = RequestMethod.GET)
  public Product getProduct() {
 
    var product = new Product();
    var productTitle = informationClient.getProductTitle();
    var productInventory = inventoryClient.getProductInventories();
 
    //Fallback to error message
    product.setTitle(requireNonNullElse(productTitle, "Error: Fetching Product Title Failed"));
 
    //Fallback to default error inventory
    product.setProductInventories(requireNonNullElse(productInventory, -1));
 
    return product;
  }
}


设置产品信息微服务的精华实现。 库存微服务类似,它只返回库存计数

@RestController
public class InformationController {
  @RequestMapping(value = "/information", method = RequestMethod.GET)
  public String getProductTitle() {
    return "The Product Title.";
  }
}


调用 聚合器 REST API返回产品信息。

curl http://localhost:端口号/product
{"title":"The Product Title.","productInventories":5}


🔍类图

87df1582f177429f9945d006561e1a84.png


🔍适用场景

当需要各种微服务的统一API时,无论客户端设备如何,都可以使用Aggregator微服务模式。


82108c8d813e4565a341ce893bed0393.gif

相关文章
|
2天前
|
监控 安全 API
探索微服务架构中的API网关模式
【6月更文挑战第13天】本文深入探讨了在现代软件开发中,微服务架构如何通过API网关模式提升系统的可扩展性、安全性和性能。我们将分析API网关的核心功能,包括请求路由、负载均衡、认证授权以及日志监控等,并讨论如何在实际项目中有效实现这些功能。
|
4天前
|
监控 负载均衡 安全
探索微服务架构中的API网关模式
【6月更文挑战第10天】本文将深入探讨微服务架构中的一个重要组件——API网关。我们将详细分析API网关的功能、优势以及在微服务架构中的关键作用,并通过实例展示如何有效实现和部署API网关以提升系统性能和安全性。
19 2
|
7天前
|
安全 API 开发者
探索微服务架构中的API网关模式
【6月更文挑战第8天】本文深入探讨了在构建可扩展的微服务系统中,API网关所扮演的关键角色。我们将从API网关的定义和作用出发,分析其如何作为系统入口统一流量管理、提供安全控制、实现服务聚合以及优化客户端与各微服务间的通信。通过具体案例,本文将展示如何有效设计API网关以提升系统的灵活性和响应速度。
|
8天前
|
监控 负载均衡 安全
微服务架构中的API网关模式
【6月更文挑战第7天】本文将深入探讨微服务架构中API网关的关键作用,分析其如何作为系统的统一入口点,实现请求路由、负载均衡、认证授权和监控日志等功能。我们将通过一个虚构的案例,展示API网关在提升系统性能和安全性方面的实际应用。
|
11天前
|
缓存 负载均衡 API
探索微服务架构中的API网关模式
【6月更文挑战第4天】在微服务架构的海洋中,API网关扮演着灯塔的角色,为复杂的服务网络提供导航。本文将深入探讨API网关的设计原则、实现方式以及它如何优化微服务间的通信流程。我们将一起揭开API网关的神秘面纱,理解其在现代软件架构中的重要性。
|
15天前
|
监控 应用服务中间件 API
探索微服务架构中的API网关模式
【5月更文挑战第31天】在这篇文章中,我们将深入探讨微服务架构中的关键组件——API网关。我们将了解API网关的定义、功能以及它如何优化微服务的通信流程,提高安全性和性能。此外,我们还将讨论一些常见的API网关实现技术,并分析它们的优势和局限性。
|
16天前
|
负载均衡 监控 安全
探索微服务架构中的API网关模式
本文深入探讨了在构建现代软件系统时,微服务架构中API网关的核心作用和实践策略。通过分析API网关的设计原则、实现技术以及面临的挑战,旨在为读者提供一套清晰的指导方针,以便在实际应用中有效地利用API网关来提升系统的可扩展性、安全性和性能。
|
16天前
|
负载均衡 监控 API
微服务架构中的API网关模式
本文将深入探讨微服务架构中的一个重要组件——API网关。我们将了解API网关的作用、实现方式以及它如何提高系统的可扩展性和安全性。通过实际案例分析,我们将展示API网关在微服务架构中的应用和优势。
|
19天前
|
设计模式 安全 Java
【设计模式】JAVA Design Patterns——Curiously Recurring Template Pattern(奇异递归模板模式)
该文介绍了一种C++的编程技巧——奇异递归模板模式(CRTP),旨在让派生组件能继承基本组件的特定功能。通过示例展示了如何创建一个`Fighter`接口和`MmaFighter`类,其中`MmaFighter`及其子类如`MmaBantamweightFighter`和`MmaHeavyweightFighter`强制类型安全,确保相同重量级的拳手之间才能进行比赛。这种设计避免了不同重量级拳手间的错误匹配,编译时会报错。CRTP适用于处理类型冲突、参数化类方法和限制方法只对相同类型实例生效的情况。
【设计模式】JAVA Design Patterns——Curiously Recurring Template Pattern(奇异递归模板模式)
|
22天前
|
设计模式 Java 数据库
【设计模式】JAVA Design Patterns——Converter(转换器模式)
转换器模式旨在实现不同类型间的双向转换,减少样板代码。它通过通用的Converter类和特定的转换器(如UserConverter)简化实例映射。Converter类包含两个Function对象,用于不同类型的转换,同时提供列表转换方法。当需要在逻辑上对应的类型间转换,或处理DTO、DO时,此模式尤为适用。
【设计模式】JAVA Design Patterns——Converter(转换器模式)