咨询热线:13534118111 联系人:谭忠伦 地址:安徽省合肥市金寨路92号
API网关模式
来源:澳门百乐门娱乐成 发布时间:2019-11-28 点击量:3
什么是网关
网关一词来源于计算机网络中的定义,网关(Gateway)又称网间连接器、协议转换器。网关的准确定义是: 两个计算机程序或系统之间的连接,网关作为两个程序之间的门户,允许它们通过不同计算机之间的协议通信来共享信息。顾名思义API网关就是API之间相互调用的关卡和屏障。
API之间为什么需要网关
试想一下我们在实现一个非常庞大的业务系统,分为不同的业务domain和子系统,各个domain和子系统提供处理业务的API,不同系统之间以API的方式进行数据交互。通常情况下我们可能会将所有实现业务功能的API集成到一起(API Center)给不同的Channel的Portal提供数据处理的能力。当有一天我们的系统需要与第三方发生交互,我们既需要暴露给外部系统调用的公开API,同时也需要调用外部的API实现自身的业务需求。此时我们将会考虑很多的问题,比如:服务之间访问的授权和认证,安全和性能的监控,缓存和日志的处理,超时的Retry,负载和熔断的处理,查询请求的聚合等等一系列的问题。此时你需要一个可以集中处理所有可能在服务调用之间需要处理的一切事情,就像是小区的物业和安保一样,需要对小区所有的业主处理职责范围内的一切事情。
这是通常情况下API网关需要帮我们处理的事情,随着系统业务的不断复杂化,我们的系统越越庞大,API的交互越来越错综复杂。此时我们可能会考虑将这个庞大的系统拆分成多个细小的domain,分别提供各自domain的API。这便是时下最流行的话题:微服务。当我们的系统演进到微服务的架构时,API网关将是系统必不可少的关键部分。在微服务体系结构中,客户端应用程序通常需要使用多个微服务的功能。客户端如果直接消费某服务,那通常情况下将需要处理和协调用多个微服务endpoint。当应用程序引入新的微服务或更新现有微服务时会发生什么?试想一下如果你的应用程序有许多微服务,那么处理和协调来自客户端如此多的endpoint的请求,那对系统来说是一场噩梦,而且由于客户端应用程序将与这些endpoint产生耦合,这将会使我们的系统边的混乱不堪。
因此,我们需要一个中间层或间接层(Gateway)来处理不同client对API的请求,这将会使得我们的应用程序处理起来非常方便。如果没有API网关,客户端应用程序必须直接向微服务发送请求,这就会产生很多混乱的问题,比如:
耦合: 如果没有API网关,客户端的应用程序将与内部微服务间耦合。客户端序需要知道实现业务需求的API分散在服务中的哪些部分,当我们开发和重构内部服务时,将会影响到客户端应用程序,并且很难维护,因为客户端应用程序需要跟踪多个服务的endpoint
多次请求:客户端应用程序中的一个页面可能需要多次调用多个服务来完成某个功能,这可能导致客户端和服务器之间的多次往返请求,增加了显著的延迟。我们知道在中间级别处理的聚合可以提高客户端应用程序的性能和用户体验。
安全问题:如果没有网关,所有的服务都必须公开给“外部世界”,这使得攻击面比隐藏内部服务更大,而这些服务不是客户端应用程序直接使用的。攻击面越小应用程序就越安全。
横切关注点:每个公开发布的服务都必须处理诸如授权、SSL等问题。在许多情况下这些关注点可以在一个层中处理,这样内部服务就可以简化,这让我想起了面向切面的编程(AOP)
什么是网关模式
当我们在使用多个客户端应用程序设计和构建大型或复杂的基于微服务的应用程序时,可以考虑使用API网关,这是为某些微服务组提供单一入口点的服务,它类似于面向对象设计的Facade(外观类)模式,但在微服务中它是系统的一部分。API网关模式的一个变体也称为“Backend for front-end”(BFF),因为你可能会根据每个客户端应用程序的不同需求创建多个API网关。因此API网关位于客户端应用程序和微服务之间,它充当反向代理将请求从客户端路由到服务,它还可以提供额外的横切特性,如身份验证、SSL终止和缓存。
下面的图显示了自定义API网关如何适合于基于微服务的体系结构。
在上面的示例中,API网关将作为自定义Web API或ASP.NET WebHost服务的一个容器运行
在该图中需要强调的是我们将使用一个面向多个不同客户端的自定义API网关服务。这可能是一个重要的风险,因为你的API网关服务将根据客户端需求的不断增长和发展,最终由于这些不同的需求,它将变得臃肿不堪,实际上它可能非常类似于单片应用程序或单片服务。这就是为什么我们非常推荐将API网关拆分为多个服务或多个更小的API网关。
在使用API网关模式时我们也要非常小心,通常使用单个API网关聚合应用程序的所有内部微服务不是一个好的实践,因为一旦这样做了它就充当一个整体聚合器或协调器并通过耦合所有微服务来违反微服务自治。因此API网关应该基于业务边界和客户端应用程序进行隔离,而不是作为所有内部微服务的单一聚合器。当把API网关层分解为多个API网关时, 如果你的应用程序有多个客户端, 这可以是一个主要的枢纽来识别多个API的网关类型,这样你就可以有不同的外观类来应对每个客户端的需求。这是我们称之为“Backend for front-end”的模式(BFF),其中每个API网关可以为每个客户端提供不同的API,甚至可能基于客户端的特定需求实现特定的适配器代码,该代码在下面调用多个内部微服务,如下图所示:
上图展示了一个带有多个细粒度API网关的简化体系结构,在这种情况下识别每个API GateWay的边界纯粹是基于BFF的模式,因此只是基于每个客户端提供各自所需的API,但在较大的应用程序也应该更进一步,以创建基于业务边界的网关作为第二设计衡量因素。
API网关模式中的主要特性
API网关可以根据产品的不同提供多种特性,它可能提供更丰富或更简单的特性,但是对于任何API网关来说,最重要和基本的特性是以下设计方式:
反向代理或网关路由:API网关提供反向代理,将请求(通常是Http请求)重新定向或路由到内部微服务的端点。网关为客户端应用程序提供一个endpoint或URL,然后在内部将请求映射到一组内部微服务。这个路由特性有助于从微服务的方式来解耦客户端,而且也很方便在单一API和客户端之间实现网关的控制,这样的话你可以添加新的API作为新的microservices同时仍然使用遗留单一的API,直到它在未来被分成许多microservices。因为API的网关的存在,客户端应用程序不会注意到所使用的API实现为内部microservices或单一的API,当在演进和和重构我们的单一API到 microservices的过程中因为有了API网关路由的存在,才不会带来Client请求的URI的变化。想了解更多网关路由的东西请戳这里。
请求聚合:作为网关模式的一部分,你可以将针对多个内部微服务的多个客户端请求(通常是Http请求)聚合到单个客户端请求中。当客户端页面需要调用来自多个微服务的数据时,这种模式特别方便。使用这种方法客户端将发送一个请求到API网关,然后网关将负责发送多个请求来获取内部microservices然后聚合结果再发送回客户端。这种设计模式的主要优点和目标是减少客户端应用程序和后端API之间的隔阂,对于微服务所在的数据中心之外的远程应用程序来说这一点尤为重要,比如移动应用程序或来自客户端远程浏览器中的Javascript的SPA应用程序的请求。对于在服务器环境中执行请求的常规web应用程序(如ASP),这种模式并不重要,因为延迟比远程客户机应用程序要小得多。是否能够执行此聚合取决于你使用的API网关产品,然而在许多情况下,在API网关的范围内创建聚合微服务将会更加的灵活,所以你也可以在代码中定义聚合(即c#代码)。想了解更多请求聚合的东西请戳这里。
横切关注点或网关卸载:根据每个API网关产品提供的特性,你可以将功能从单个微服务转移到网关,通过将横切关注点合并到一层来简化每个微服务的实现。这对于可以在每个内部微服务(如以下功能)中正确实现的复杂的特殊功能来说特别方便。
身份验证和授权服务发现集成响应缓存重试策略,断路器和QoS。速度限制和节流负载平衡日志记录、跟踪、相关性头文件、查询字符串和声明转换IP白名单
根据每个实现API网关产品可以提供更多的横切关注点,但这些都是最常见的特性。例如Azure API管理提供了这些特性中的大部分,以及许多对商业API非常有用的高级特性。但是对于更简单的方法,像Ocelot这样的轻量级API网关是相当灵活的,因为你可以将它部署到你所选择的环境和你的微服务。有关网关卸载模式的更多信息请戳这里。
本篇文章主要是介绍了API的网关模式的特性,文章是来自微软官方博客并加入了自己的一点理解。译文来自:https://blogs.msdn.microsoft.com/cesardelatorre/2018/05/15/designing-and-implementing-api-gateways-with-ocelot-in-a-microservices-and-container-based-architecture/
参考资料:
API Gateway
http://microservices.io/patterns/apigateway.html
https://docs.microsoft.com/en-us/azure/architecture/microservices/gateway
Aggregation and composition pattern
http://microservices.io/patterns/data/api-composition.html
相关产品
-
新京报讯 (记者房亮)昨日下午,在权健和天津松江联合召开的新闻发布会上,关于孙可的转会纠纷事件终于有了结果。据介绍,孙可将回到舜天继续参加下赛季中超联赛,并效力至明年年底。
-
动力方面,新车将提供2.3T EcoBoost发动机和5.0L自然吸气V8发动机可选,其中5.0L自然吸气V8发动机新增直喷系统,使得其动力和燃油经济性更佳。而现款车型的3.7L V6将停止使用。传动方面,敞篷版有望使用福特最新的10速自动变速箱。(文/汽车之家 李长宁)
-
目前,每个喜剧节目最后都要追求感人效果,都要让观众两眼泪汪汪,使人一度以为换错了台,但是创作者有不少都觉得好像只有这样才能提升节目的意义,但每期都如此高频率地走煽情路线,让整个喜剧节目充满浓浓的悲情气质,就不太对劲了,况且这样难免都让人觉得有些同质化,从而产生逆反心理。
-
DMJ顾问公司首席经济师戴维·琼斯说:“让女性担任美联储主席是重要的一步,这一观点颇为有力。毫无疑问,她的经验可以担此重任。” (卜晓明)
-
中新网11月14日电 据外媒报道,泰国卫生部医学科学厅厅长素空13日透露,在检查化验警方此前缴获的10种药物后,发现一种每板10片状的新型安眠药,致死率是普通安眠药的10倍。
-
马提罗斯岩在采访中声称,自己对戈洛夫金并不害怕,因为自己有足够的实力与他抗衡,对于能够与拳坛名将格洛夫金进行对战,让他感到很兴奋,这一次的拳击比赛,自己并非仓促准备的,在与戈洛夫金团队达成协议之前,自己就一直在进行训练了,这次的比赛自己信心十足,自己已经发现了他的不足之处,戈洛夫金将会在5月的比赛上输给自己。
-
“巴萨VS皇马,第14分钟”,西班牙《每日体育报》报道,该报已经发起了一项行动,要将本周末的西班牙国家德比转变为对传奇巨星克鲁伊夫的致敬,在本周末巴萨对皇马的比赛第14分钟,全场球迷都会高呼克鲁伊夫的名字。
-
中新社莫斯科2月1日电 (记者 王修君)针对乌克兰方面提出的“乌军机遭俄方射击”的说法,当地时间1日,俄罗斯黑海舰队司令部发表声明,称该说法“完全是谎言”。
热点资讯
- 员工爆料:马斯克动不动就解雇人员工都不敢走近他2019-07-09
- 阿里京东瞄准了“新年”市场,亚马逊也加入了这场战斗。2019-11-23
- 哔哩哔哩《守望先锋》战队或定名“电磁炮”:相关商标已申请2019-10-29
- Symfony——如何使用Assetic实现资源管理2019-11-26
- 차준환,피겨핀란디아트로피은메달…2연속銀쾌거2019-11-22
- 蓝思科技股东群欣公司质押2462万股占其所持股份的8.55%2019-11-19
- 5种坚果+2种果干,考拉兄弟旗舰店每日坚果25g*30包54.9元2019-11-14
- 陕西:用三年时间集中开展农村人居环境整治2019-11-20