大家好呀,我是楼仔 。
发现最近最近很多号主发网关的文章,质量参差不齐,建议直接看这篇,有理论,有实战 。
不 BB,上文章目录:
文章插图
1 API网关基础1.1 什么是API网关API网关是一个服务器,是系统的唯一入口 。 从面向对象设计的角度看,它与外观模式类似 。
API网关封装了系统内部架构,为每个客户端提供一个定制的API 。它可能还具有其它职责,如身份验证、监控、负载均衡、缓存、协议转换、限流熔断、静态响应处理 。
API网关方式的核心要点是,所有的客户端和消费端都通过统一的网关接入微服务,在网关层处理所有的非业务功能 。通常,网关也是提供REST/HTTP的访问API 。
1.2 网关的主要功能微服务网关作为微服务后端服务的统一入口,它可以统筹管理后端服务,主要分为数据平面和控制平面:
- 数据平面主要功能是接入用户的HTTP请求和微服务被拆分后的聚合 。使用微服务网关统一对外暴露后端服务的API和契约,路由和过滤功能正是网关的核心能力模块 。另外,微服务网关可以实现拦截机制和专注跨横切面的功能,包括协议转换、安全认证、熔断限流、灰度发布、日志管理、流量监控等 。
- 控制平面主要功能是对后端服务做统一的管控和配置管理 。例如,可以控制网关的弹性伸缩;可以统一下发配置;可以对网关服务添加标签;可以在微服务网关上通过配置Swagger功能统一将后端服务的API契约暴露给使用方,完成文档服务,提高工作效率和降低沟通成本 。
文章插图
- 路由功能:路由是微服务网关的核心能力 。通过路由功能微服务网关可以将请求转发到目标微服务 。在微服务架构中,网关可以结合注册中心的动态服务发现,实现对后端服务的发现,调用方只需要知道网关对外暴露的服务API就可以透明地访问后端微服务 。
- 负载均衡:API网关结合负载均衡技术,利用Eureka或者Consul等服务发现工具,通过轮询、指定权重、IP地址哈希等机制实现下游服务的负载均衡 。
- 统一鉴权:一般而言,无论对内网还是外网的接口都需要做用户身份认证,而用户认证在一些规模较大的系统中都会采用统一的单点登录(Single Sign On)系统,如果每个微服务都要对接单点登录系统,那么显然比较浪费资源且开发效率低 。API网关是统一管理安全性的绝佳场所,可以将认证的部分抽取到网关层,微服务系统无须关注认证的逻辑,只关注自身业务即可 。
- 协议转换:API网关的一大作用在于构建异构系统,API网关作为单一入口,通过协议转换整合后台基于REST、AMQP、Dubbo等不同风格和实现技术的微服务,面向Web Mobile、开放平台等特定客户端提供统一服务 。
- 指标监控:网关可以统计后端服务的请求次数,并且可以实时地更新当前的流量健康状态,可以对URL粒度的服务进行延迟统计,也可以使用Hystrix Dashboard查看后端服务的流量状态及是否有熔断发生 。
- 限流熔断:在某些场景下需要控制客户端的访问次数和访问频率,一些高并发系统有时还会有限流的需求 。在网关上可以配置一个阈值,当请求数超过阈值时就直接返回错误而不继续访问后台服务 。当出现流量洪峰或者后端服务出现延迟或故障时,网关能够主动进行熔断,保护后端服务,并保持前端用户体验良好 。
- 黑白名单:微服务网关可以使用系统黑名单,过滤HTTP请求特征,拦截异常客户端的请求,例如DDoS攻击等侵蚀带宽或资源迫使服务中断等行为,可以在网关层面进行拦截过滤 。比较常见的拦截策略是根据IP地址增加黑名单 。在存在鉴权管理的路由服务中可以通过设置白名单跳过鉴权管理而直接访问后端服务资源 。
- 灰度发布:微服务网关可以根据HTTP请求中的特殊标记和后端服务列表元数据标识进行流量控制,实现在用户无感知的情况下完成灰度发布 。
- 流量染色:和灰度发布的原理相似,网关可以根据HTTP请求的Host、Head、Agent等标识对请求进行染色,有了网关的流量染色功能,我们可以对服务后续的调用链路进行跟踪,对服务延迟及服务运行状况进行进一步的链路分析 。
推荐阅读
- 微笑|公务员招聘年龄放宽至40周岁,打破门槛后,大学生的机会更渺茫?
- 白敬亭|白敬亭宋轶领证,微博之夜大秀恩爱,爆料者晒出证据
- 李微敖|奔着白鹿去看《跑男》,却被25岁关晓彤吸引,鹿晗眼光真的绝!
- 贾静雯|张继科事件后续:李微敖死锤,杨幂疑似声讨,安踏率先终止合作
- 考研|华科热门专业本科毕业生两次考研失利,卑微求工作,长衫脱不下去
- 赵丽颖|被微博之夜“除名”的赵丽颖,已经在另一条路上越走越远
- 肖战|虞书欣站姐一张博君一肖P图,败光肖战粉丝微博之夜新建立的好感
- 景甜|景甜称19年差点丢失自己,受这大委屈微笑面对!在寂寞中学会宽容
- 张继科|张继科欠款合同被李微敖曝光,景甜私密视频泄露,债主被判7年
- 赵丽颖|赵丽颖和肖央官宣了:太甜了!