12

我创建了几个 RESTful 微服务并将它们 docker 化。现在我想为他们提供一个基于 Web 的 UI,并能够创建用户并授予他们使用某些 API 的权限。

我知道我需要某种 API 网关。我的第一个想法是我总是可以用蛮力的方式来做:创建一些 django 应用程序来提供 UI 并手动代理所有对 API 的请求,但这似乎很乏味。也许有一些替代方案?我已经准备好使用 Tyk,但找不到任何有关添加用户和授予他们权限的信息。

我可能可以创建一个用作 API 网关的应用程序,并通过编写一些对其进行建模的代码来自动代理请求。因此,例如,我基本上需要外部 url 到实际 api url 和一些授权逻辑之间的映射。也许已经有类似的东西了?

4

3 回答 3

18

我一直在寻找类似的东西,包括对速率限制、UI 控制台等的支持。它归结为一些免费增值工具,例如:

和一些开源的:

我决定使用 tyk,因为它有一个不错的 UI 控制台和可靠的文档。Quora上都提到了所有这些,当你想去购物时这很好:)

于 2015-07-29T07:56:54.003 回答
4

如果您喜欢亲自动手,您可以很容易地实现自己的简化 API 网关。我相信这种方法非常适合微服务范式——实现具有有限功能的简单服务,它只做一件事,但做得很好。

我已经写了一篇关于这个主题的教程(使用 Node.js 为 Dockerized 微服务实现简单的 API 网关)。我的例子是大约 100 行 JavaScript 代码,它使用node-docker-monitor来监听 Docker 事件和http-proxy来处理来自客户端的 HTTP 请求。

https://memz.co/api-gateway-microservices-docker-node-js/

或 SkyDNS 和 Nginx 的替代解决方案

https://memz.co/reverse-proxy-nginx-docker-microservices/

于 2016-04-06T00:18:32.857 回答
0

除非我弄错了(我对容器有点陌生)——我认为来自Amazon AWS的所有这些解决方案(AWS API Gateway本身在它们前面供公众访问)也属于免费增值解决方案的范畴用于在公共 API 网关后面运行/编排 Docker 容器:

以下是有关使用 AWS API Gateway 的 AWS 博客:

并且根据您的要求,其中任何一个(也来自 Amazon AWS)也应该满足用户、账户、权限、授权等方面的要求:

顺便说一句,我不认为任何中间管理/计算/服务器对于使用其中任何一个进行架构都是必要的(尽管仍然可以出于任何目的插入来自AWS EC2和/或AWS Lambda的计算),因为它们都是 AWS服务 [管理其功能] 自己。

于 2020-03-28T00:09:05.047 回答