首页 > 解决方案 > 函数执行耗时 60012 毫秒,完成状态为:'timeout'

问题描述

问题摘要:我想从我的 Firebase Cloud Function 向我的 node.js 后端触发一个 POST 请求,该后端当前在我的本地计算机上运行。函数执行开始,但 POST 调用永远不会到达后端。

开发环境:

预期结果:来自 Firebase Cloud Function 的 POST 调用触发 node.js 后端中的路由以处理 POST 调用中接收到的数据。

实际结果:POST 调用永远不会到达当前在本地计算机上运行的 node.js 后端。登录 Firebase Cloud Functions 控制台:

函数执行耗时 60012 毫秒,完成状态为:'timeout'

到目前为止我尝试了什么?

Firebase 云功能代码:

const functions = require('firebase-functions');
const axios = require('axios');
const admin = require('firebase-admin');
admin.initializeApp();

const BACKEND_URL = 'http://XXX.XXX.X.XX:3000';

exports.triggerNotification = functions.database.ref('/sessions/{sessionID}/{message}')
  .onCreate(function(snapshot, context) {
    const createdContent = snapshot.val();
    const config = { headers: { 'Content-Type': 'application/json' } };
    if (!createdContent) {
      return;
    }
    return axios.post(`${BACKEND_URL}/notification/trigger`, { createdContent } ,config);
  });

Node.js 后端代码:

router.post('/trigger', function (req, res) {
  console.log('req.body', req.body);
  res.status(200).send('Post request received');
}); 

标签: node.jsfirebase-realtime-databaseaxiosgoogle-cloud-functions

解决方案


看起来您正在使用 IP 地址,并且后端正在本地计算机上运行,​​因为您尝试了 localhost 并且它的格式与您的代码中的格式类似。你说邮递员工作,但你是从网络外部尝试吗?我的猜测是连接被阻塞了。您可以尝试像 ngrok 这样公开本地服务器的服务吗?还要确保使用 https 进行尝试


推荐阅读