AWS Lambda - Funktion in NODEJS
Nodejs ist eine der Sprachen, die von der AWS Lambda-Funktion unterstützt werden. Die von nodejs unterstützte Version ist v6.10 und v8.10. In diesem Kapitel werden wir verschiedene Funktionen der AWS Lambda-Funktion in NODEJS im Detail kennenlernen.
Handler in NodeJS
Um die AWS Lambda-Funktion in nodejs zu schreiben, sollten wir zuerst einen Handler deklarieren. Der Handler in nodejs ist der Name der Datei und der Name der Exportfunktion. Der Name der Datei lautet beispielsweiseindex.js und der Name der Exportfunktion lautet lambda handler, so ist sein entsprechender Handler index.lambdahandler
Beobachten Sie einen hier gezeigten Beispielhandler -
exports.lambdahandler = function(event, context, callback) { //code goes here}
Parameter zum Handler
Der Handler ist der Hauptkern für den Aufbau der Lambda-Funktion. Der Handler akzeptiert drei Parameter:event, context und callback.
Ereignisparameter
Es werden alle Details des Ereignisses ausgelöst. Wenn wir beispielsweise die Lambda-Funktion verwenden, die in S3 ausgelöst wird, enthält das Ereignis Details zum S3-Objekt.
Kontextparameter
Es enthält die Details des Kontexts wie die Eigenschaften und Konfigurationsdetails der Lambda-Funktion.
Rückruffunktion
Es hilft dabei, dem Anrufer Details zurückzugeben. Die Struktur des Rückrufs sieht wie folgt aus:
callback(error, result);
Die Parameter der Rückruffunktion werden nachfolgend erläutert -
Error −Dies enthält Details, wenn während der Ausführung der Lambda-Funktion ein Fehler aufgetreten ist. Wenn die Lambda-Funktion erfolgreich ist,null kann als erster Parameter für die Rückruffunktion übergeben werden.
Result −Dies gibt die Details der erfolgreichen Ausführung der Lambda-Funktion an. Wenn ein Fehler auftritt, wird der Ergebnisparameter ignoriert.
Note −Die Rückruffunktion in AWS Lambda muss nicht verwendet werden. Falls keine Rückruffunktion vorhanden ist, gibt der Handler diese als null zurück.
Die gültigen Rückrufsignaturen sind unten angegeben -
callback(); // It will return success, but no indication to the caller
callback(null); // It will return success, but no indication to the caller
callback(null, "success"); // It will return the success indication to the caller
callback(error); // It will return the error indication to the caller
Immer wenn AWS Lambda ausgeführt wird, werden die Rückrufdetails wie Fehler oder Erfolg in AWS CloudWatch zusammen mit etwaigen Konsolenmeldungen protokolliert.
Arbeiten mit AWS Lambda in Nodejs8.10
Lassen Sie uns verstehen, wie Sie mit AWS Lambda in nodejs8.10 arbeiten und die Funktion synchron und asynchron aufrufen.
Synchrones Aufrufen der Lambda-Funktion
Das folgende Beispiel gibt Ihnen eine Vorstellung davon, wie Sie die Lambda-Funktion synchron aufrufen können:
exports.handler = function(event, context, callback) {
let arrItems = [4,5,6,8,9,10,35,70,80,31];
function countevennumbers (items) {
return new Promise(resolve => {
setTimeout(() => {
let a = 0;
for (var i in items) {
if (items[i] % 2 == 0) {
a++;
}
}
resolve(a);
},2000);
});
}
let evennumber = countevennumbers(arrItems);
callback(null,'even numbers equals ='+evennumber);
};
Nach dem Testen dieses Codes in der AWS-Konsole können Sie die folgende Ausgabe beobachten:
Beachten Sie, dass die Ausgabe des obigen Codes ein Versprechungsobjekt ist. Die Anzahl wird nicht angegeben, da die Anzahl innerhalb eines setTimeout erhöht wird und der Funktionsaufruf nicht auf die Ausführung in setTimeout wartet und das Versprechen-Objekt zurückgibt.
Wenn wir hätten async/await Bei der Handler-Funktion wird die Lambda-Funktion exakt ausgegeben.
Asynchrones Aufrufen des Handlers
Das folgende Beispiel gibt Ihnen eine Vorstellung davon, wie Sie die Lambda-Funktion asynchron aufrufen können:
exports.handler = async function(event, context, callback) {
let arrItems = [4,5,6,8,9,10,35,70,80,31];
function countevennumbers (items) {
return new Promise(resolve => {
setTimeout(() => {
let a = 0;
for (var i in items) {
if (items[i] % 2 == 0) {
a++;
}
}
resolve(a);
}, 2000);
});
}
let evennumber = await countevennumbers(arrItems);
callback(null,'even numbers equals ='+evennumber);
};
Wir haben hinzugefügt async und awaitim obigen Code. Wenn wir verwendenawaitNeben dem Funktionsaufruf wird die Ausführung angehalten, bis das Versprechen innerhalb der Funktion aufgelöst wird. Beachten Sie, dassawait ist nur gültig für async Funktionen.
Nach dem Testen dieses Codes in der AWS-Konsole können Sie die folgende Ausgabe beobachten:
ContextDetails in NodeJS
Das Kontextobjekt enthält Details wie den Namen der Lambda-Funktion, die verbleibende Zeit in Millisekunden, die Anforderungs-ID, den Namen der Cloudwatch-Gruppe, Zeitüberschreitungsdetails usw.
Die folgende Tabelle zeigt die Liste der Methoden und Attribute, die mit dem Kontextobjekt verfügbar sind.
Methode für Kontextobjekt verfügbar
Sr.Nr. | Methodenname & Beschreibung |
---|---|
1 | getRemainingTimeInMillis() Diese Methode gibt die verbleibende Zeit in Millisekunden an, bis die Lambda-Funktion die Funktion beendet |
Für das Kontextobjekt verfügbare Attribute
Sr.Nr. | Attributname & Beschreibung |
---|---|
1 | functionName Dies gibt den AWS Lambda-Funktionsnamen an |
2 | functionVersion Dadurch wird die Version der AWS Lambda-Funktion ausgeführt |
3 | nvokedFunctionArn Dies gibt ARN Details. |
4 | memoryLimitInMB Dies zeigt das Speicherlimit, das beim Erstellen der Lambda-Funktion hinzugefügt wurde |
5 | awsRequestId Dies gibt die AWS-Anforderungs-ID an. |
6 | logGroupName Dies gibt den Namen des Cloudwatch-Gruppennamens an |
7 | logStreamName Dies gibt den Namen des Cloudwatch-Protokolldatenstromnamens an, in den die Protokolle geschrieben werden. |
8 | identity Dies gibt Details über den Amazon Cognito Identity Provider an, wenn er mit aws mobile sdk verwendet wird. Details angegeben sind wie folgt -
|
9 | clientContext Dies zeigt Details der Client-Anwendung an, wenn sie mit aws mobile sdk verwendet wird. Die angegebenen Details lauten wie folgt:
|
Schauen Sie sich das folgende Beispiel an, um eine bessere Vorstellung vom Kontextobjekt zu erhalten:
exports.handler = (event, context, callback) => {
// TODO implement
console.log('Remaining time =>', context.getRemainingTimeInMillis());
console.log('functionName =>', context.functionName);
console.log('AWSrequestID =>', context.awsRequestId);
console.log('logGroupName =>', context.log_group_name);
console.log('logStreamName =>', context.log_stream_name);
console.log('clientContext =>', context.clientContext);
callback(null, 'Name of aws Lambda is=>'+context.functionName);
};
Nach dem Testen dieses Codes in der AWS-Konsole können Sie die folgende Ausgabe beobachten:
Nach dem Testen dieses Codes in der AWS-Konsole können Sie die folgende Protokollausgabe beobachten:
Anmelden bei NodeJS
Wir können console.log zum Anmelden in NodeJS verwenden. Die Protokolldetails können vom CloudWatch-Dienst über die Lambda-Funktion abgerufen werden.
Beachten Sie zum besseren Verständnis das folgende Beispiel:
exports.handler = (event, context, callback) => {
// TODO implement
console.log('Logging for AWS Lamnda in NodeJS');
callback(null, 'Name of aws Lambda is=>'+context.functionName);
};
Nach dem Testen dieses Codes in der AWS-Konsole können Sie die folgende Ausgabe beobachten:
Sie können den folgenden Screenshot von CloudWatch aus sehen -
Fehlerbehandlung in NodeJS
Lassen Sie uns verstehen, wie die Fehlerbenachrichtigung in NodeJS erfolgt. Beachten Sie den folgenden Code -
exports.handler = function(event, context, callback) {
// This Source code only throws error.
var error = new Error("something is wrong");
callback(error);
};
In der Protokollausgabe können Sie Folgendes beobachten:
Die Fehlerdetails werden im Rückruf wie folgt angegeben:
{
"errorMessage": "something is wrong",
"errorType": "Error",
"stackTrace": [ "exports.handler (/var/task/index.js:2:17)" ]
}