微服务--网关

本文涉及的产品
服务治理 MSE Sentinel/OpenSergo,Agent数量 不受限
简介: 网关 一、为什么使用网关? 1) 客户端的需求量与每个微服务暴露的细粒度API数量的不匹配。 (比如,移动客户端一个页面,需要请求上百个微服务,没有效率) 2)客户端请求微服务的协议可能并不是web友好型。

网关
  • 一、为什么使用网关?
    • 1) 客户端的需求量与每个微服务暴露的细粒度API数量的不匹配。 (比如,移动客户端一个页面,需要请求上百个微服务,没有效率)
    • 2)客户端请求微服务的协议可能并不是web友好型。(每个服务的协议可能不一样,应用应该在防火前外采用类似http协议)
      • 一个服务可能是用Thrift的RPC协议,而另一个服务可能是用AMQP消息协议。它们都不是浏览或防火墙友好的,并且最好是内部使用。应用应该在防火墙外采用类似HTTP或者WEBSocket协议。
    • 3)很难重构;
      • 随着时间的推移,我们可能需要改变系统微服务目前的切分方案。例如,我们可能需要将两个服务合并或者将一个服务拆分为多个。但是,如果客户端直接与微服务交互,那么这种重构就很难实施。
  • 二、定义:
    •  一个服务器,或者说是进入系统的唯一节点;
    • 封装内部系统的架构,提供api给各个客户端(facade模式(外观模式)很像。 外观模式是在适配器模式下把多个方法整合到一个对外的方法中。);
    • 负责请求转发、合成和协议转换。  (比如: 可以在web协议与内部使用的非Web友好型协议间进行转换,如HTTP协议、WebSocket协议。);
    • 定制化的api (客户端请求的数据需要多个服务时,它只提供一个服务点就可以,不用客户端请求多个服务)。
  • 三、网关的用途:
    • 负责负载均衡、缓存、访问控制、请求分片和管理、静态响应处理、授权、监控等任务;
  • 四、优缺点
    • 优点:
      • 封装应用内部结构;客户端直接跟gatway交互更简单点。API Gateway提供给每一个客户端一个特定API,这样减少了客户端与服务器端的通信次数,也简化了客户端代码。
    • 缺点:
      • 是一个高可用的组件,必须要开发、部署和管理;可能成为开发的瓶颈,开发者必须更新API Gateway来提供新服务提供点来支持新暴露的微服务。更新API Gateway时必须越轻量级越好。
      • 否则,开发者将因为更新Gateway而排队列。但是,除了这些缺点,对于大部分的应用,采用API Gateway的方式都是有效的。
  • 五、实现
    • 设计要求:
      • 性能和可扩展性:
        • 只有少数公司需要每天处理大规模(上亿)的请求;对于大部分应用,网关的性能和可扩展性是非常重要的。支持同步、非阻塞I/O的网关。
        • 例子: jvm中,采用基于NIO技术的Netty; Nginx Plus提供一个成熟的、可扩展的、高性能web服务器和反向代理,它们均容易部署、配置和二次开发。
      • 采用反应性编程模型:  
        • 因为有一些请求,需要调用多个后端服务并合并结果处理,如果发送给后端服务的请求是相互独立的,可以并发的处理这些请求;如果这些请求之间是有依赖的,必须向请求A,才能请求B。
        • 比如java8 的 completableFuture,支持 多任务并发执行、支持任务完成的先后顺序,原生的api,返回每个任务的异常, api丰富。
        • 如果利用传统的同步回调方法实现Api的合并会很麻烦,代码复杂且难以维护。比较好的解决方法就是: 反应性编程模型,比如java8的completableFuture 和 js 的Promise 。
      • 服务调用:
        • 一个基于微服务的应用是一个分布式系统,并且必须采用线程间通信的机制。两种线程间通信的方法: 1、采用异步机制,基于消息代理的方法;如JMS、AMQP;2、采用同步机制,如Thrift、Http。
        • 系统会同时采用同步和异步两种机制。
        • 网关将需要支持多种通信机制。
      • 服务发现:
        • 网关需要知道每一个微服务的IP和端口,在传统应用中,采用硬编码;在云基础的微服务应用中,采用服务发现机制。
        • 两种方式: 服务端发现与客户端发现(网关需要查询服务注册处,也就是微服务实例地址的数据库)。
      • 处理部分失败:
        • 在分布式系统中当一个服务调用另一个服务超时或者不可用的情况,就会发生部分失败。
        • 网关不应该被阻断并处于无限期等待下游服务的状态,如何处理这种失败依赖于特定的场景和具体服务。比如:
          • 产品详情页中,推荐模块无响应,其他信息比如图片、价格等应该返回给用户,推荐部分可以返回空、也可以固定返回几个;如果是产品信息服务无响应,网关应该给客户端返回一个错误。
          • 当缓存有效时,网关应该能返回缓存。比如,产品的价格变化并不频繁,网关在价格服务不可用时应返回缓存中的数值。这个缓存可以有网关本身实现,也可以借助redis 等这类外部缓存实现,通过
          • 返回缓存数据或者默认数据,网关确保系统错误不影响用户体验。
        • Netflix Hysrix 对于实现远程服务调用代码来说是一个非常好用的库。Hystrix记录那些超过预设定的极限值的调用。它实现了circuit break模式,使得可以将客户端从无响应服务的无尽等待中停止。
        • 如果一个服务的错误率超过预设值,Hystrix将中断服务,并且在一段时间内所有请求立刻失效。Hystrix可以为请求失败定义一个fallback操作,例如读取缓存或者返回默认值。
        • 如果你在用JVM,就应该考虑使用Hystrix。如果你采用的非JVM环境,那么应该考虑采用类似功能的库。
    • 六、总结
      • 对于大多数微服务基础的应用,实现一个API Gateway都是有意义的,它就像是进入系统的一个服务提供点。API Gateway负责请求转发、请求合成和协议转换。
      • 它提供给应用客户端一个自定义的API。API Gateway可以通过返回缓存或者默认值的方式来掩盖后端服务的错误。


    • 原文链接:https://www.nginx.com/blog/building-microservices-using-an-api-gateway/


    • 参考链接:http://dockone.io/article/482


    • 虽然使用SpringCloud 已经很长时间,但是细细读下来这篇文章,收益匪浅。简单的翻译和整理了一下,如有错误,还望指正。

相关文章
|
1月前
|
API
阿里云微服务引擎及 API 网关 2024 年 2 月产品动态
阿里云微服务引擎及 API 网关 2024 年 2 月产品动态
|
5月前
|
负载均衡 应用服务中间件 API
微服务技术系列教程(25) - SpringCloud- 接口网关服务Zuul
微服务技术系列教程(25) - SpringCloud- 接口网关服务Zuul
56 0
|
7月前
|
负载均衡 安全 Java
深入了解Spring Cloud Gateway:构建高效微服务网关
Spring Cloud Gateway是一个强大的微服务网关,它在现代分布式架构中扮演着至关重要的角色。本文将深入介绍Spring Cloud Gateway的核心概念、功能和用途,以帮助您更好地理解和利用这一工具来构建高效的微服务应用。
|
7月前
|
缓存 监控 负载均衡
服务网关:微服务架构的前门与护卫
在微服务架构中,服务网关扮演着关键的角色,充当着微服务系统的前门和护卫。本博客将深入探讨服务网关的概念、重要性以及如何在微服务环境中充分发挥其作用。
|
4月前
|
Java 数据安全/隐私保护 数据格式
Spring Cloud Gateway 网关整合 Knife4j 4.3 实现微服务接口文档聚合
Spring Cloud Gateway 网关整合 Knife4j 4.3 实现微服务接口文档聚合
|
30天前
|
SpringCloudAlibaba Java 网络架构
【Springcloud Alibaba微服务分布式架构 | Spring Cloud】之学习笔记(七)Spring Cloud Gateway服务网关
【Springcloud Alibaba微服务分布式架构 | Spring Cloud】之学习笔记(七)Spring Cloud Gateway服务网关
81 0
|
3天前
|
API
阿里云微服务引擎及 API 网关 2024 年 3 月产品动态
阿里云微服务引擎及 API 网关 2024 年 3 月产品动态。
|
3天前
|
监控 JavaScript 安全
构建微服务架构下的API网关
【4月更文挑战第15天】在微服务架构中,API网关扮演着至关重要的角色。它作为系统的唯一入口,不仅负责请求的路由、负载均衡和认证授权,还涉及到监控、日志记录和服务熔断等关键功能。本文将探讨如何构建一个高效且可靠的API网关,涵盖其设计原则、核心组件以及实现策略,旨在为后端开发人员提供一套实用的指导方案。
18 4
|
26天前
|
消息中间件 缓存 API
微服务架构下的API网关性能优化实践
在现代的软件开发中,微服务架构因其灵活性和可扩展性被广泛采用。随着服务的细分与增多,API网关作为微服务架构中的关键组件,承担着请求路由、负载均衡、权限校验等重要职责。然而,随着流量的增长和业务复杂度的提升,API网关很容易成为性能瓶颈。本文将深入探讨API网关在微服务环境中的性能优化策略,包括缓存机制、连接池管理、异步处理等方面的具体实现,旨在为开发者提供实用的性能提升指导。
|
28天前
|
缓存 负载均衡 监控
构建高效微服务架构:API网关的作用与实践
【2月更文挑战第31天】 在当今的软件开发领域,微服务架构已成为实现系统高度模块化和易于扩展的首选方法。然而,随着微服务数量的增加,确保通信效率和管理一致性变得尤为重要。本文将探讨API网关在微服务架构中的核心角色,包括其在请求路由、安全性、负载均衡以及聚合功能方面的重要性。我们将通过具体案例分析,展示如何利用API网关优化后端服务,并讨论实施过程中的最佳实践和常见挑战。