使用 Google Cloud Functions 发送过大的响应时出现“错误:无法处理请求”

Amb*_* B. 3 google-cloud-datastore google-cloud-functions

这里有一点上下文:目前,我们正在使用 Google Cloud Datastore 在我们的应用程序中存储许多不同类型的记录,并且我们正在使用 Google Cloud Functions 返回来自各种类型的所有记录。我们通过 HTTP 请求执行此操作,因此这是一个 HTTP 触发器。就在昨晚,我们遇到了一个问题,当我们所有field同类记录的总大小太大时,我们的端点突然失败并显示“错误:无法处理请求”。

我们对此的包装器相当简单:我们的端点接受种类的类型作为路径参数,运行带有该种类所有记录的过滤器的数据存储查询,然后用于res.send发送查询的结果。

起初,这似乎是交易规模超过谷歌提供的限制的问题。但是,当我添加更多日志记录时,我确定查询确实正确地找到了所有字段记录,没有发生任何意外;然而,不知什么原因,它在 的最后一步坏了res.status(200).send(resultsArr);

这显然与发送回的响应的大小有关,因为降低所有实体的总大小是成功的。在这一点上,我唯一能想到的是res.send不会发回这种大小的响应,但是在谷歌搜索时我找不到关于这些限制的任何信息。

有没有人遇到过这样的事情?有谁知道对此有什么好的预期解决方案?我知道我们可以在有限制的情况下多次调用端点,但我担心这是一个问题。遇到查询大小的限制是一回事,但我没想到res.send它会在这里限制我们。

(编辑:是的,响应超过 10MB。如果您需要帮助确定这是否是您的问题,您可以使用以下内容进行验证:

let size = Buffer.from(JSON.stringify(resultsArr)).length; console.log('Attempting to send response of size:', size);)

Dou*_*son 5

HTTP 触发器的传入和传出有效负载的限制当前设置为 10MB,如此处所述