/goku_lite

A Powerful HTTP API Gateway in pure golang!Goku API Gateway (中文名:悟空 API 网关)是一个基于 Golang开发的微服务网关,能够实现高性能 HTTP API 转发、服务编排、多租户管理、API 访问权限控制等目的,拥有强大的自定义插件系统可以自行扩展,并且提供友好的图形化配置界面,能够快速帮助企业进行 API 服务治理、提高 API 服务的稳定性和安全性。

Primary LanguageGoGNU General Public License v3.0GPL-3.0

Apinto

Go Report Card Releases LICENSE Contributor Covenant


Apinto是一款高性能、可扩展、易维护的云原生API网关。

Apinto网关基于GO语言模块化开发,5分钟极速部署,配置简单、易于维护,支持集群与动态扩容,并且提供几十款网关插件和实用的企业级插件,让用户开箱即用。

Demo

体验地址:demo-dashboard.apinto.com

提供了三个试用账号,避免被使用者挤下来

账号:apinto-1

密码:12345678

账号:apinto-2

密码:12345678

账号:apinto-3

密码:12345678

快速入门:https://help.apinto.com/docs/dashboard-v2/quick/quick_start.html

Apinto Dashboard github地址: https://github.com/eolinker/apinto-dashboard

Apinto功能架构图:

img_v2_22590d84-f8a4-4d3a-9c67-b481ecfdf1fg

Apinto亮点特性

Apinto API 网关以出色的用户体验和适用于各种企业级业务场景的控制台为特色。控制台具有四大亮点功能:集群管理、应用管理、精细服务治理和企业插件,能够满足企业对 API 网关更高级场景化需求的要求。

集群管理

Apinto 提供集群管理功能,可以一次性配置业务并将其发布到相应的集群。这解决了多集群维护多套业务配置的问题,显著提高了运维效率,并降低了繁杂配置时的事故率。

应用管理

Apinto 网关推出应用管理概念,统一管理应用及其生命周期。作为业务通讯的发起者,应用贯穿整个调用链。Apinto 网关对应用请求的流量进行鉴权认证和服务治理,并对请求的流量进行监控告警,统计应用调用情况。

精细化服务治理

Apinto提出精细化流量管理方案,即所有调用方的请求流量都经过网关,通过对应用、API、上游服务、请求方式、IP、请求路径、应用自定义标签等组合条件筛选请求流量,执行限量、访问、熔断、灰度、缓存等策略规则,帮助企业快速、灵活地制定策略,以满足不同业务场景的需求,并全方位治理好服务。

企业插件

Apinto网关即将推出企业插件模块,并且陆续提供业务型企业插件如:用户角色权限、监控告警、日志、API文档、开放平台、安全防护、数据分析、调用链、mock、在线调测、安全测试、国密、多协议等。支持用户自定义企业插件,支持独立部署。

Apinto功能

Apinto网关可以作为业务流量的入口,可以对业务流量进行处理,如动态路由、负载均衡、服务发现、熔断降级、身份认证、监控与告警等。 Apinto网关不受云平台限制,也能在Kubernetes运行。

产品特性

功能 描述
集群 集群不限制网关节点,自由剔除或加入网关节点,主从网关节点具备无缝切换功能,提升网关高可用性
动态路由 可通过设置location、query、header、host、method等参数匹配对应的服务
服务发现 支持对接Eureka、Nacos、Consul
负载均衡 支持轮询权重算法
用户鉴权 匿名、Basic、Apikey、JWT、AK/SK认证
SSL证书 管理多个证书
访问域名 可为网关设置访问域名
健康检查 支持对负载的节点进行健康检查,确保服务健壮性
协议 HTTP/HTTPS、Webservice、Restful、gRPC、Dubbo2、SOAP
插件化 流程插件化,按需加载所需模块
OPEN API 支持使用open api配置网关
日志 提供节点的运行日志,可根据日志设置的等级输出
多种日志输出 可将节点的请求日志输出到不同的日志接收器,如file、nsq、kafka等
Cli命令支持 通过Cli命令操控网关,插件安装、下载和网关的开启、关闭等操作均可使用一键命令操控
黑白名单 支持多维度筛选流量,设置黑白名单IP,拦截非法IP
访问策略 支持多维度筛选流量,可针对应用、IP、应用与IP、应用与API、应用与上游等多维组合设置黑白名单
流量策略 支持多维度筛选流量,控制应用、应用与API、应用与上游之间的请求次数和请求报文大小限制
熔断策略 支持多维度筛选流量,熔断上游或API
灰度策略 支持多维度筛选流量,按百分比或高级规则灰度流量到目标节点
缓存策略 支持多维度筛选流量,缓存API响应内容
参数映射 将客户端的请求参数映射到转发请求中,可按需改变参数的位置及名称
额外参数 转发请求时,额外加上后端验证参数,如apikey等
转发重写 支持对 schemeurihost 的重写,同时支持对转发请求的请求头部header的值进行新增或者删除
流量镜像 线上流量或请求内容进行拷贝到镜像服务中
MOCK 模拟web服务器端API的响应
CORS 支持api请求跨域
同步API 提供OpenAPI同步API文档,支持swagger3.0 json或yaml格式文件

迭代计划

image 如果您是个人开发者,可基于API网关相关的业务场景开发有价值的网关插件或企业级插件,并且愿意分享给Apinto,您将会成为Apinto的杰出贡献者或得到一定的收益。 如果您是企业,可基于Apinto网关开发企业级插件,成为Apinto的合作伙伴。

Star历史

Star History Chart

基准测试

image

部署

启动

1.下载安装包并解压(此处以v0.12.1版本的安装包示例)

wget https://github.com/eolinker/apinto/releases/download/v0.12.1/apinto_v0.12.1_linux_amd64.tar.gz && tar -zxvf apinto_v0.12.1_linux_amd64.tar.gz && cd apinto

Apinto支持在arm64、amd64架构上运行。

请根据需要下载对应架构及系统的安装包,安装包下载请点击跳转

  1. 安装网关:
./install.sh install

执行该步骤将会生成配置文件/etc/apinto/apinto.yml/etc/apinto/config.yml,可根据需要修改。

3.启动网关:

apinto start

Bug 和需求反馈

如果想要反馈 Bug、提供产品意见,可以创建一个 Github issue 联系我们,十分感谢!

如果你希望和 Apinto 团队近距离交流,讨论产品使用技巧以及了解更多产品最新进展,欢迎加入以下渠道。

  • 联系我们