基于 node.js 的网关设计.

2020-12-03 22:13:45 +08:00
 qfdk

最近需要设计一个 node.js 的网关.

简单来说就是一个 nodejs 的反向代理.

Spring 全家桶 里面有 Zuul 这个看门口

网上都看了一圈 有这么几个选择

为了避免造轮子,想跟诸位老哥请教一下.

说一下我们基本的需求:

再次 谢过

4249 次点击
所在节点    Node.js
20 条回复
chogath
2020-12-04 10:30:57 +08:00
可以参考下 `@acheetahk/request` 的 fastProxy
chogath
2020-12-04 10:32:18 +08:00
chogath
2020-12-04 10:32:31 +08:00
有问题可以给我提 issue
kenshinhu
2020-12-04 15:01:10 +08:00
kong gateway
qfdk
2020-12-04 15:33:26 +08:00
@kenshinhu 这个看到了 不过不是 nodejs 的技术栈 虽然性能厉害
qfdk
2020-12-04 15:39:28 +08:00
@chogath humm 回头我好好看一下 不想造轮子
生产环境用一个开源项目要看下后面的生态的 还有文档等等. 感谢🙏
chogath
2020-12-07 10:07:12 +08:00
@qfdk node.js 没有单独做网关的开源包,有的只是零散的方法,目前来看方案有三种:

1. 使用 http request pipe 重写,代理到目标服务器完成请求转发
2. 使用 websocket 的方式完成请求转发 # https://docs.nestjs.cn/7/websockets # 参考资料来自 nest.js
3. 使用 grpc 自己实现 interface + 协议 + 传输格式 + 异常信息定义 # https://docs.nestjs.cn/7/microservices?id=grpc #参考资料来自 nest.js
chogath
2020-12-07 10:08:50 +08:00
我是用的 1 + 3,1 适合常规业务直接调用,3 适合服务间调用(指多个服务调用,或者形成了调用链)
chogath
2020-12-07 10:10:28 +08:00
@qfdk 我建议你先吧目前你觉得合适的方案跑成 demo,做一下性能压测和各方面的评估。
qfdk
2020-12-09 01:30:59 +08:00
@chogath 感谢你先 现在看了好几套方案 明天跟同事一起聊一下看看要不要自己做一个. express Gateway 里面坑有些多 开源的大多数不够活跃 最后一次提交都在 1 年多了. 加上一些 redis 的库也没法用. 初步考虑可能用 koa2. 毕竟 Gateway 主要是为了性能来的. 您的建议很好👍
qfdk
2021-01-26 16:27:17 +08:00
∫好了 现在 开始撸轮子了,基于 https://github.com/chimurai/http-proxy-middleware 鉴权用 passport
qfdk
2021-09-14 14:11:03 +08:00
已经上线了!
qfdk
2021-12-27 17:09:10 +08:00
@chogath 回来看看,发现还好自己撸了一个…..
LawlietZ
2021-12-28 15:21:06 +08:00
@qfdk 给您发了 github 上标的邮件
lf978
2022-08-29 22:14:11 +08:00
老哥 有啥设计思路可以借鉴借鉴吗? 刚好想搞一个
lf978
2022-08-29 22:17:29 +08:00
希望能咨询下哈哈,TEY5Nzg5NTUwMzM=
qfdk
2022-08-29 22:18:30 +08:00
@lf978 我这里是 Gateway 也鉴权了, 等于这里是个有状态的. 根据请求来判断 某些人是否有某些权限. 如果 token 快要过期了 也是 gateway 续签,token 还有十秒 就续签. 这样请求不会出奇怪的问题. 还有个好处 这样客户端没有 token.
lf978
2022-08-29 22:38:55 +08:00
@qfdk 是来了一个 http 请求 然后 gateway 在发出去一个 http 请求吗? 然后 gateway 保留状态。
qfdk
2022-08-30 00:47:23 +08:00
@lf978 #18 不是,是这样的。gateway 的作用 可以把来的流分给不同的 微服务,每个微服务有不同的权限。正常没有状态的做法是每个微服务会鉴权一下。鉴权的方式是通过 token 鉴权的。 思想是 gateway 处理请求的统一鉴权,因为 gateway 相当于一个反向代理,这里收到的 http 请求 你知道 这个请求有没有鉴权。如果你搞过前端,有的是通过访问 /current/user 这样来确定你是否登录。但是用了 gateway 任何请求都知道你有没有登录。因为 gateway 那边会存一个 session 这个 session 用来记录用户的状态。不知道明白了没有 ?
lf978
2022-08-30 09:38:59 +08:00
@qfdk 嗯嗯 我懂你说的, 我是做前端的, 想问下: 可以把来的流分给不同的 “微服务” 这个微服务在这里是指后端的 http 接口是吧

这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。

https://www.v2ex.com/t/731916

V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。

V2EX is a community of developers, designers and creative people.

© 2021 V2EX