AJAX 请求在1分钟后超时

我以前创建了一个 Discourse 插件,它通过 ajax 调用控制器方法,然后返回结果。这个特定的请求可能需要几分钟才能完成,而且以前运行得很好。
但现在,在很长一段时间后,我在当前的 Discourse 版本中尝试使用该插件时遇到了一个问题,即请求在 1 分钟后被中止。

代码如下:

ajax("/my-plugin/import", {
        type: "POST",
        data: {
          categoryId: this.categoryId,
          otherData: ...
        }
      }).then((result) => { ... });

1 分钟后我看到的错误消息是:

Discourse Ember CLI Proxy Error

FetchError: request to http://127.0.0.1:3000/my-plugin/import failed, reason: socket hang up
at ClientRequest. (file:///src/app/assets/javascripts/node_modules/node-fetch/src/index.js:108:11)
at ClientRequest.emit (node:events:526:35)
at Socket.socketOnEnd (node:_http_client:525:9)
at Socket.emit (node:events:526:35)
at endReadableNT (node:internal/streams/readable:1359:12)
at process.processTicksAndRejections (node:internal/process/task_queues:82:21)

我想了解的是,为什么这种行为在过去一年里可能会发生变化?以及是否有任何选项可以更改超时设置。

我认为这里没有发生任何近期更改。Discourse 的后端配置为在开发环境中将请求设置为 60 秒超时,在生产环境中设置为 30 秒超时。

看起来这可以通过 UNICORN_TIMEOUT 环境变量在开发环境中进行配置。但生产环境是硬编码为 30 秒。

2 个赞

也许您想安排作业来处理导入。

3 个赞

最后,我重写了它以在计划任务中处理导入,事实证明这要好得多。

2 个赞

This topic was automatically closed 30 days after the last reply. New replies are no longer allowed.