【发布时间】:2019-03-28 06:58:12
【问题描述】:
我遇到了云功能中冷启动时间的典型(根据许多帖子)问题。一个似乎承诺的解决方案建议只导入/导出实际正在执行的函数,如下所示:
https://github.com/firebase/functions-samples/issues/170#issuecomment-323375462
if (!process.env.FUNCTION_NAME || process.env.FUNCTION_NAME === 'sendFollowerNotification') {
exports.sendFollowerNotification = require('./sendFollowerNotification');
}
这是一个 Javascript 示例,但我使用的是打字稿。我尝试了许多变体,虽然有一些构建,但最后我总是卡在我的函数没有被导出并部署警告我要删除现有函数。
这是众多尝试之一:
if (!process.env.FUNCTION_NAME || process.env.FUNCTION_NAME === 'generateInviteURL') {
import ('./invite_functions').then ((mod) => { console.log ("mod follows" ); console.log (mod); exports.generateInviteURL = functions.https.onRequest( mod.generateInviteURL ); } )
.catch ((err) => {console.log ("Trying to import/export generateInviteURL ", err);}) ;
}
如上所述,在部署时发生的情况是我收到有关该功能被删除的警告。
我能够通过以下方式“避免”该消息:
console.log ("Function name: ", process.env.FUNCTION_NAME);
function dummy_generateInviteURL (req, res) { ; }
exports.generateInviteURL = functions.https.onRequest( dummy_generateInviteURL );
if (!process.env.FUNCTION_NAME || process.env.FUNCTION_NAME === 'generateInviteURL') {
console.log ("Doing the good import");
import ('./invite_functions').then ((mod) => { console.log ("mod follows" ); console.log (mod); exports.generateInviteURL = functions.https.onRequest( mod.generateInviteURL ); } )
.catch ((err) => {console.log ("Trying to import/export generateInviteURL ", err);}) ;
}
console.log ("Exported");
console.log (exports.generateInviteURL);
当然,空函数总是会被导出,但如果是被调用的函数,就会被真实的函数替换。
在这种情况下,日志如下所示:
generateInviteURL Function name: generateInviteURL generateInviteURL
generateInviteURL Exported generateInviteURL
{ [Function: cloudFunction] __trigger: { httpsTrigger: {} } }
所以第一部分看起来很有希望(定义了环境变量),然后导入做了一些事情(进入 then 块,从不捕获),但导出的变量没有被替换。
我不确定这是 TypeScript 问题、firebase 问题还是开发人员问题 - 可能我只是遗漏了一些明显的东西。
那么问题 - 我如何避免导入/导出每个特定功能不需要的任何东西?
【问题讨论】:
-
所有 JavaScript 都是有效的 TypeScript。您是否尝试将原始代码保持原样以查看它是否有效?还是你需要更多的东西?
-
@DougStevenson 它的一个变体(使用 require 而不是 import)确实有效(因为它构建和部署,但似乎对冷启动时间没有显着影响)。老实说,我开始导入的东西是因为 typescript headers 上的 require 会导致错误/警告。
-
我通常会忽略 VS Code 中的这些警告。 import 与 require 不完全相同。此时通常无法避免一些冷启动时间(尤其是 Firestore)。
标签: node.js typescript firebase google-cloud-functions firebase-cli