美文网首页docker net core技术
小白入门微服务(3) - 什么是 API gateway

小白入门微服务(3) - 什么是 API gateway

作者: zone7_ | 来源:发表于2018-09-26 00:27 被阅读29次

    概述

    • 前言
    • 什么是 API gateway
    • 为什么要用 API gateway
    • 后记

    前言

    一开始吧,感觉我也描述不好什么是 API gateway,在看了这篇文章https://microservices.io/patterns/apigateway.html)之后,感觉豁然开朗,那么我这边就用我的语言来描述一遍。如果我的文章对你有帮助,欢迎关注、点赞、转发,这样我会更有动力做原创分享。

    什么是 API gateway

    API gateway 处于客户端与各个微服务之间,它担任了反向代理的角色,将不同的请求路由到相对应的微服务中去。与此同时,它还有以下功能:安全,限流,缓存,日志,监控,重试,熔断等。

    为什么要用 API gateway

    首先我们来大胆想想一下,你是一个公司的 CTO,你公司的产品是要做一个类似于当当的卖书产品,叫【叮叮当当】。那么你的产品可能有以下三端:

    • 网页版
    • Android/iOS 客户端
    • 小程序
      当然你的产品做得足够大的话,你有必要开放一些给第三方调用的 REST API 接口。
      那么现在来讨论一下产品的一些功能:
    • 登录注册(登录注册、用户基础信息的存取)
    • 价格服务(记录价格、双十一特价、秒杀价、优惠券价等价格的计算)
    • 产品服务(产品信息、名称、单价、图片展示)
    • 库存服务(记录产品库存)
    • 评价服务(购买商品后的客户评价、讨论区)
    • 第三方开放接口(例如:微信开放平台,提供给第三个调用的接口)

    那么问题来了:
    问题来了:
    来了:

    • 客户端与众多微服务交互,协议不统一,有些协议是对客户端不友好的。
    • 数据不统一,可能在一个操作中,需要多个微服务的数据组装起来,才是我们一次请求想要的数据。
    • 微服务 ip 和 port 改变,客户端无法感知。
    • 不同的终端需要不同的数据,移动端可能仅仅 json 数据就能解决问题,网页端可能需要更多的数据展示。
    • 关于鉴权,众多微服务,难道每个微服务都独立拥有一套鉴权系统吗?

    解决方案 -- API gateway(如图)
    使用 API gateway,那么众多问题都得到解决:

    • 各个微服务先与 API gateway 交互,转换成客户端友好的 REST API。
    • 在 API gateway 中组装好数据再返回给客户端。
    • 在 API gateway 中修改 ip 与 port 客户端无感知,正常使用。
    • 采用多个 API gateway ,不同 API gateway 响应不同的数据给不同终端。
    • 在 API gateway 中统一鉴权,省去多余代码。
    产品架构 多 API gateway 架构

    如此修改之后,众多问题都迎刃而解,客户端对众多微服务是无感知的。

    后记

    真正的微服务架构还远不止这些东西,还有服务注册、服务发现等等。这里只是带领你入个门,后面会循序渐进,逐步走向完整。很高兴你能看到这里,又进一步学习了微服务。
    个人的知识储备总是有限的,如有错误的地方,还请大佬斧正。点击阅读原文,链接到我的知乎,我会在知乎上对文章错误的地方进行修改。

    本篇文章首发于公众号「zone7」,关注公众号获取最新推文,后台回复【小白微服务】获取源码。

    相关文章

      网友评论

        本文标题:小白入门微服务(3) - 什么是 API gateway

        本文链接:https://www.haomeiwen.com/subject/piqggftx.html