javascript - "Notification URL"的替代方案来处理 Node 中长时间运行的 API 进程

标签 javascript node.js api express

我正在构建一个 API,该 API 需要很长时间才能返回数据,转换发生时最多需要 60 秒。在运行时,我希望让用户了解任何错误,并通知他们我们处于转换阶段的哪个进程。

这在客户端上非常容易,因为我可以简单地发送 WebSocket 事件,但对于公共(public) API,这不太实用。

我知道我可以请求通知 URL 并向给定 URL 发送更新,但这似乎很麻烦并且可能占用大量资源。还有其他更有效的方法来发送进度通知吗?

理想情况下,使用 API 的用户能够进行设置。

.on("错误", 函数(err) { //处理错误 });

或者类似的东西。

最佳答案

您不太清楚 API 的使用者是谁、他们使用的客户端类型或工作流程是什么样子。因此,根据您正在寻找的内容以及您拥有的可用资源,会有很多不同的答案。

非详尽列表:

REST 端点轮询

了解您不是粉丝,但这仍然是为广泛的客户提供此服务的最佳方法之一,也是(据我所知)为纯粹基于浏览器执行此操作的仅有两种方法之一客户。就性能而言,如果您适本地设置缓存策略并对客户端设置限制(无论如何您都应该这样做),那么这并不可怕。我不同意这是一个供客户使用的 PITA,但这是观点,你显然有不同的感觉。缓解 PITA 的一种方法是提供一个为消费者处理该机制的 SDK。

网络套接字

我知道您可能正在处理并非从网络开始的客户端,但如果客户端可以发出 RESTful 请求,并且客户端表示有兴趣建立 Web 套接字,则您可以将服务器设置为进行网络套接字升级相同的。我不喜欢这个选项,因为它对我来说更复杂(更多移动部件),但如果您喜欢 Web 套接字并且所有/大多数客户端都支持 Web 套接字,那么这是一个选项。或者,您可以将 REST 响应设为您为该客户端打开的 Web 套接字的 URL。

网络 Hook

如果您的客户端可能是其他计算机(尤其是服务器),那么网络 Hook 是一个非常好的方法,特别是如果您想要引发的事件可能会以不可预测的时间间隔多次发生。在此方案中,客户端向您发出 REST 请求,他们发送给您的部分数据包括一个 URL,当事件发生时您将向该 URL 发布数据(以您在 API 中指定的格式)。显然,他们要么必须将该 URL 保留给您的 POST,要么您可以就您的服务器将尊重的某种凭证达成一致。

TCP 套接字

与 Web Socket 选项类似,您可能有一个 REST 请求到达您的端点,然后使用套接字连接信息/URI 响应自定义 TCP 套接字。这有点不标准,但在正确的用例中可能非常有用且高效。我已经有一段时间没有使用它了,所以他们可能已经改变了它,但这就是 Heroku 的 API 用来处理流日志的方式。

Pub/Sub 或消息队列或类似

Redis 可以做到这一点,其他许多也可以。在这种情况下,您正在制定一种更通用的解决方案,其中可能有多个事件 channel 客户端可以订阅,等等。出于安全原因,我不喜欢直接公开 Redis,这意味着您仍然需要弄清楚如何处理 Redis 和客户端之间的通信(见上文),但在幕后使用它至少会给您带来一些概念逻辑处理发布者和订阅者等;正如我所说,如果您有多个事件,则很有用。不过,这是一个比上面更重量级的解决方案,并且会增加您的系统管理开销一定程度(取决于您的高可用性需求等)

关于javascript - "Notification URL"的替代方案来处理 Node 中长时间运行的 API 进程,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/39965144/

相关文章:

javascript - 如何从数组中提取图像并将其放入列表中

javascript - 输入数据验证过程出错

node.js - 没有 id 的 PUT 请求

javascript - 使用 shelljs 将 exec stdout 与一些文本进行比较

api - SalesForce API查询不显示自定义字段

javascript - React - GSAP w/ScrollMagic - 无法添加场景选项 'tweenChanges' ,因为它已经存在

node.js - 在内存中缓冲数据 - Writable.final() Hook 从未被调用

api - 使用 swagger 2.0 对表单数据 API 请求进行建模

php - Google Search Console API - SearchAnalytics 500 错误

javascript - 将字符串参数从 node.js 传递到 C++ 代码(使用 SWIG)