Questo è in ritardo, ma nel caso in cui qualcun altro è alla ricerca:
Zippare cartella del progetto al posto dei contenuti della cartella di progetto può causare questo. La cartella zippata, una volta estratta, non dovrebbe contenere una cartella con i file lambda al suo interno, ma dovrebbe avere il file index.js e la cartella node_modules a livello di root.
un esempio di lavoro di una funzione lambda è (che utilizza l'ultimo materiale lucido Firebase * sigh *):
var firebase = require('firebase');
// Your service account details
var credentials = {
"type": "service_account",
"project_id": "project-123451234512345123",
"private_key_id": "my1private2key3id",
"private_key": "-----BEGIN PRIVATE KEY-----InsertKeyHere-----END PRIVATE KEY-----\n",
"client_email": "[email protected]",
"client_id": "1111222223333344444",
"auth_uri": "https://accounts.google.com/o/oauth2/auth",
"token_uri": "https://accounts.google.com/o/oauth2/token",
"auth_provider_x509_cert_url": "https://www.googleapis.com/oauth2/v1/certs",
"client_x509_cert_url": "https://www.googleapis.com/robot/v1/metadata/x509/projectname%40project-123451234512345123.iam.gserviceaccount.com"
};
firebase.initializeApp({
serviceAccount: credentials,
databaseURL: "https://project-123451234512345123.firebaseio.com"
});
exports.handler = function (event, context, callback) {
// I use some data passed in from AWS API Gateway:
if (!event.firebaseUid) {
callback('Missing param for id');
}
firebase.database().ref().child('users').child(firebaseUid).child('at').set(newTokens.access_token).then(function (data) {
console.log('Firebase data: ', data);
firebase.database().goOffline();
callback(null, 'Firebase data: ', data);
}).catch(function (error) {
callback('Database set error ' + error);
});
};
Ora per l'avvertimento. Ho sperimentato questo causando il timeout della funzione lambda anche dopo che è avvenuta la richiamata firebase, ad es. la funzione set sembra creare un listener che mantiene aperta la funzione lambda nonostante il ritorno dei dati corretti.
Aggiornamento: chiamata a firebase.database(). GoOffline() risolve il problema di timeout della funzione Lambda che si verificava.
Le normali precauzioni relative alla sicurezza non vengono verificate o appropriate e si applicano le possibilità di arrestare lo spazio e il tempo utilizzando questo.
sto lavorando sulla mia macchina locale al momento (in java script), ma anche la mia funzione si è bloccata alla fine. goOffline() non funziona nel mio caso. Come l'hai risolto? –
sto lavorando al mio computer locale al momento (nello script java), ma alla fine la mia funzione si è bloccata. goOffline() non funziona nel mio caso. Come l'hai risolto? –
@ risposta di josiah-choi sotto risolto il problema per me - vedi 'context.callbackWaitsForEmptyEventLoop = false' – dsl101