首页 > 解决方案 > Google Cloud Functions 结束时:使用 Axios 时超时

问题描述

我想使用带有 http 触发器的 Google Cloud 函数将数据写入 Google 电子表格。

以下代码是我的云功能:

exports.writeDataMaterialCollection = functions.https.onRequest(
  (req, res) => {
    if (req.method === "POST") {
      console.log(req.body);
      res.set("Access-Control-Allow-Origin", "*");
      const sheets = google.sheets({ version: "v4" });
      var jwt = getJwt();
      var apiKey = getApiKey();
      var spreadsheetId = "sheetIDxxxxxxxxx";
      var range = "A:L";
      var row = ["data"];
      sheets.spreadsheets.values.append(
        {
          spreadsheetId: spreadsheetId,
          range: range,
          auth: jwt,
          key: apiKey,
          valueInputOption: "RAW",
          resource: { values: [row] }
        },
        (err, result) => {
          if (err) {
            throw err;
          } else {
            console.log(result.data.updates.updatedRange);
            res.status(200).send(result.data.updates.updatedRange);
          }
        }
      );
    }
  }
);

当我发出 curl POST 请求时,数据会正确写入电子表格。

url -d '{"test": "wert"}' -X POST http://localhost:5001/XXXX/writeDataMaterialCollection

问题

我不明白的是,当我在 Vue.js 中使用 Axios 时,Google Cloud Function 返回 throw new Error("Function timed out.")

axios(
        "http://localhost:5001/XXXXX/writeDataMaterialCollection",
        {
          method: "POST",
          headers: {
            "content-type": "application/json",
            "Access-Control-Allow-Origin": "*"
          },
          data: {
            daten1: 23
          }
        }
      ).then(response => (self.writeDataResult = response));

标签: javascriptnode.jsaxiosgoogle-cloud-functions

解决方案


如果您的函数达到这一点:

throw err;

它实际上不会终止该函数并将该错误传播给客户端。那是因为您从回调函数中抛出错误,而不是主函数。这也意味着函数将超时,因为没有响应被发送到客户端。

您应该做的是向客户端发送错误,以便函数可以正确终止,并且客户端可以接收错误。您可能还想考虑记录错误,这样您就可以在控制台中看到出了什么问题:

if (err) {
  res.send(500);
  console.error(err);
}

推荐阅读