适用于Firebase超时的云功能

时间:2017-07-28 01:05:44

标签: javascript firebase firebase-realtime-database google-cloud-functions

获取数据库数据的简单云功能无效。

getusermessage()无效

错误:

  

函数执行耗时60002毫秒,完成状态:'超时'

Index.JS获取数据库结果。

const functions = require('firebase-functions');
const admin = require('firebase-admin');
admin.initializeApp(functions.config().firebase);
const cors = require('cors')({origin: true});

// Take the text parameter passed to this HTTP endpoint and insert it into the
// Realtime Database under the path /messages/:pushId/original
exports.addMessage = functions.https.onRequest((req, res) => {
  // Grab the text parameter.
  const original = req.query.text;
  // Push the new message into the Realtime Database using the Firebase Admin SDK.
  admin.database().ref('/messages').push({original: original}).then(snapshot => {
    // Redirect with 303 SEE OTHER to the URL of the pushed object in the Firebase console.
    res.redirect(303, snapshot.ref);
  });
});

// Listens for new messages added to /messages/:pushId/original and creates an
// uppercase version of the message to /messages/:pushId/uppercase
exports.makeUppercase = functions.database.ref('/messages/{pushId}/original')
    .onWrite(event => {
      // Grab the current value of what was written to the Realtime Database.
      const original = event.data.val();
      console.log('Uppercasing', event.params.pushId, original);
      const uppercase = original.toUpperCase();
      // You must return a Promise when performing asynchronous tasks inside a Functions such as
      // writing to the Firebase Realtime Database.
      // Setting an "uppercase" sibling in the Realtime Database returns a Promise.
      return event.data.ref.parent.child('uppercase').set(uppercase);
    });

var db = admin.database();
exports.getUserMessage = functions.https.onRequest((req, res) => {
var query = db.ref("messages").orderByKey();
query.once("value")
  .then(function(snapshot) {
    snapshot.forEach(function(childSnapshot) {
      var key = childSnapshot.key;
      // childData will be the actual contents of the child
      var childData = childSnapshot.val();
  });
});  
});

O做错了什么?

2 个答案:

答案 0 :(得分:11)

你没有说你的三个功能中的哪一个超时,但我会猜测哪一个。您的HTTPS函数getUserMessage未生成对客户端的响应。云功能将等待60秒(默认情况下)以生成响应,如果不生成,它将终止该功能并将该消息保留在日志中。

HTTPS函数中的每个代码路径都应该为客户端生成一些响应。

答案 1 :(得分:0)

您可以在函数声明期间使用runWith设置超时和内存,

exports.getUserMessage = functions.runWith({ memory: '2GB', timeoutSeconds: 360 }).https.onRequest(