• 浅谈 API 网关


    前言

    在物联网中,像监控、传感器等设备,需要将收集到的数据和信息进行汇总时,我们就需要一个 API 网关来接收从千百个终端发出的请求。

    API 网关能实现 对外统一接口,对内进行负载均衡 的功能。极大地方便了 API 系统的开发与维护。今天我们来浅谈一下 API 网关的结构和功能。

    什么是 API 网关?

    API 网关 即 API Gateway ,是一个能够实现高性能 HTTP 转发、多租户管理、API 访问权限控制等目的的微服务网关。

    拥有强大的自定义插件系统可以自行扩展,提供友好的图形化配置界面,能够快速帮助企业进行 API 服务治理、提高 API 服务的稳定性和安全性。

    使用 API 网关有哪些优势?

    • 将内部系统中重复的组件抽取出来并放置在 Goku 网关上运行,如进行用户授权、访问控制、防火墙、数据转换等;
    • 提供服务编排的功能,让企业可以快速从各类服务上获取需要的数据,对业务实现快速响应。

    • 简单、快速、低成本、低风险地 实现系统微服务化、系统集成、向合作伙伴、开发者开放数据 等多项功能。

    Eolink API 网关的主要功能

    • 部署管理

    网关支持 多集群管理 ,可以为不同集群分别配置不同的后端服务地址。以下插件:流控控制、API 流量控制、OAuth2 鉴权、OAuth2 第三方认证、数据缓存 需要用到 Redis ,若不使用这些插件可不配置 Redis 。

    多个节点的作用主要是作为 nginx 的负载和集群高可用。

    节点的负载能力取决于三个因素:网关软件性能硬件性能网络环境 ,所以还需要结合业务量和硬件资源来判断。

    业务量加大,可以通过增加节点数量水平拓展网关集群。

    • 灵活的路由

    服务是一组可访问的 API ,您可以给不同服务 设置不同的访问权限、IP黑白名单、流量控制等插件

    不同的服务可以设置不同的路由,有的服务根据请求参数路由,有的服务根据 Header 字段进行路由等。一条路由可以包含多个指标,路由指标包括 Header、Query、Location 。

    假设需要使用 Host 头部和 Location 进行路由,并且 Host 在路由时会优先判断,那么创建路由指标时,输入框的填写内容如下:

    路由创建完后,点击操作栏的 路由规则 按钮,给具体的规则绑定访问策略,当 Header 或 Location 条件符合路由到服务 test1 :

    • 注册中心和负载

    注册中心

    支持动静态注册服务,动态注册中心支持对接热门的第三方注册中心,如Eureka、Consul、Nacos等,注册中心可以设置健康检查,转发时剔除异常后端。

    负载

    配置负载时,需要先创建 服务注册方式 ,这样可以让多个负载后端接入相同的注册中心,也可以使用相同的健康检查。

    负载的服务类型分为静态服务和动态服务,静态服务 :若直接在控制台上配负载的IP,然后选择该服务的注册中心。

    服务发现:若希望网关的转发后端IP与注册中心保持一致,实时进行更新,然后选择相应的注册中心即可。

    • API 访问控制

    通过网关来做转发需要以下四个步骤:

    流程示例:

    • 监控告警

    能够针对全局或单个 API 设置告警规则和具体通知的人,支持邮件和 Webhook 等告警方式,可对接企业内部告警系统。

    网关支持自定义 API 告警机制,包括全局和单个 API 。

    告警指标包括:请求总数转发总数请求失败数转发失败数超时数 ;告警条件包括:大于、小于、等于。

    • 插件

    网关提高丰富的处理插件,如鉴权、IP黑白名单、流量控制、数据缓存等。

    也支持自定义插件,用户可以根据自己的需求做插件开发。

    网关需要采用插件化的思路进行开发设计,通过可视化的配置插件来对所有 API 服务进行控制,插件可以针对整个微应用也可以针对某一个细粒度的 API 。

    Eolink API 网关支持自行开发插件,满足特定功能需求。

    总结

    总的来说,API网关可以根据具体需要对各终端使用不同的通信协议来进行协议适配,从而实现简化应用层数据采集和分析工作的目的

    上图演示流程中的API微服务网关工具为 Eolink ,它是一个能够实现高性能 HTTP 转发、API 访问权限控制等目的的微服务网关,拥有强大的自定义插件系统可以自行扩展,能够快速帮助企业进行 API 服务治理、提高 API 服务的稳定性和安全性。

    如果有兴趣,您可自行使用:www.eolink.com

  • 相关阅读:
    Linux控制台中,‘单引号‘和“双引号“的区别
    Stream流
    浏览器视频倍速播放方法
    抖音矩阵系统源代码开发部署--SaaS开源技术开发文档
    驱动DAY9
    【Unity100个实用小技巧】如何修改UI上材质的Shader
    强平jraft阻塞和运维问题-试验对比计划
    unity打AB包,AssetBundle预制体与图集(二)
    FPGA——SPI总线控制flash(1)(含代码)
    一个基于Notes的CMR应用程序
  • 原文地址:https://blog.csdn.net/qq_40857096/article/details/126172602