什么是Kong

当我们决定对应用进行微服务改造时,应用客户端如何与微服务交互的问题也随之而来,毕竟服务数量的增加会直接导致部署授权、负载均衡、通信管理、分析和改变的难度增加。

面对以上问题,API GATEWAY是一个不错的解决方案,其所提供的访问限制、安全、流量控制、分析监控、日志、请求转发、合成和协议转换功能,可以解放开发者去把精力集中在具体逻辑的代码,而不是把时间花费在考虑如何解决应用和其他微服务链接的问题上。

为什么使用Kong

在众多API GATEWAY框架中,Mashape开源的高性能高可用API网关和API服务管理层——KONG(基于NGINX)特点尤为突出,它可以通过插件扩展已有功能,这些插件(使用lua编写)在API请求响应循环的生命周期中被执行。于此同时,KONG本身提供包括HTTP基本认证、密钥认证、CORS、TCP、UDP、文件日志、API请求限流、请求转发及NGINX监控等基本功能。目前,Kong在Mashape管理了超过15,000个API,为200,000开发者提供了每月数十亿的请求支持。

怎样使用

我们在云帮的应用市场中已经为您准备好了Kong,可以一键试部署,下面介绍怎样在云帮平台中部署和使用Kong。

部署

首先登录云帮平台,在我的应用中新建一个组,然后在云市中找到Kong,将它安装在自定义的组中,如下:

Kong(API Gateway) - 图1

安装好以后,点击组名查看该组的拓扑图:

Kong(API Gateway) - 图2

组件说明: Kong:这个就是kong,它具有对客户端请求的转发、认证、限流等功能。 Kong-Dashboard:Kong的WEB客户端,通过它可以在页面上查看和管理Kong。 Kong-Database:一个PostgreSQL数据库,它被Kong依赖,存放Kong运行时产生的数据。 newinfo:一个用于测试的web服务,包含一个rest api:GET /api/newinfos person:一个用于测试的web服务,包含一个rest api:GET /api/persons mysql5.5:mysql数据库,被newinfoperson所依赖。

添加API

  • 等待所有组件启动以后,访问Kong-Dashboard组件,进入Kong的管理页面,点击CREATE AN API
  • 填写以下选项,其它选项默认:
  • 同样的方式将newinfo也添加进入。
  • 点击页面上的APIs,如下:

Kong(API Gateway) - 图3

访问

接下来,回到云帮平台管理页面,访问Kong,并在其链接后加上/p就可以访问到person组件的GET /api/persons

Kong(API Gateway) - 图4

Kong(API Gateway) - 图5

加入自定义API

假设我们现在有一个叫web的应用,它含有一个REST API:GET /api/applist,那么将这个API注册到Kong的步骤如下:

  • 将自定义的应用添加到Kong的依赖中,如下:

Kong(API Gateway) - 图6

  • 然后在弹出的框中选择自定义的应用。

  • 重启Kong。

  • 按照前面“添加API”的步骤,将自定义的API添加到Kong即可。

参考

其他微服务架构支持

原文: https://www.rainbond.com/docs/stable/microservice/kong/kong.html