首页 > 解决方案 > 从 AWS Lambda 使用 Firebase 导致任务超时

问题描述

我正在使用 Lambda 函数创建具有 Firebase 身份验证的用户,然后将它们保存在我自己的数据库中。

var firebase = require('firebase-admin')
const serviceAccount = require('./firebase.json')
firebase.initializeApp({
    credential: firebase.credential.cert(serviceAccount),
    databaseURL: 'https://*****.firebaseio.com'
})

exports.handler = function(event, context, callback) {

    const {email, password, name, ...} = event

    firebase.auth().createUser({
        email,
        emailVerified: false,
        password,
        displayName: name,
        disabled: false
    })
    .then(firebaseResult => {
        const {uid} = firebaseResult
        return saveUserAtDatabase({email, name, ...})
    })
    .then(result => {
        callback(null, result)
    })
}

该用户是在 Firebase 和我的数据库中创建的,但是当我在 AWS Lambda 上运行它时,它会引发以下错误:

{"errorMessage":"2019-01-07T21:25:49.095Z c...e9 Task timed out after 6.01 seconds"}

无论我从函数中增加多少时间或设置更高的内存,它仍然会引发相同的错误。

标签: node.jsfirebaseaws-lambdafirebase-authentication

解决方案


我解决了问题设置context.callbackWaitsForEmptyEventLoop=false

这是因为callback等待事件循环为空,而使用 firebase.auth().createUser() 不会发生这种情况。此处记录了该context.callbackWaitsForEmptyEventLoop选项http://docs.aws.amazon.com/lambda/latest/dg/nodejs-prog-model-context.html

当此属性设置为 时false,Lambda 会冻结容器,但在您调用 时不会清除事件循环callback


推荐阅读