Verwenden der Lambda-Funktion mit Amazon Kinesis
AWS KinesisDer Dienst wird zum Erfassen / Speichern von Echtzeit-Tracking-Daten verwendet, die von Website-Klicks, Protokollen und Social-Media-Feeds stammen. Wir können AWS Lambda auslösen, um zusätzliche Verarbeitung für diese Protokolle durchzuführen.
Voraussetzungen
Die grundlegenden Voraussetzungen für den Einstieg in Kinesis und AWS Lambda sind wie folgt:
- Erstellen Sie eine Rolle mit den erforderlichen Berechtigungen
- Erstellen Sie einen Datenstrom in Kinesis
- Erstellen Sie eine AWS Lambda-Funktion.
- Fügen Sie Code zu AWS Lambda hinzu
- Fügen Sie Daten zum Kinesis-Datenstrom hinzu
Beispiel
Lassen Sie uns an einem Beispiel arbeiten, in dem wir AWS Lambda für die Verarbeitung des Datenstroms von Kinesis auslösen und E-Mails mit den empfangenen Daten senden.
Ein einfaches Blockdiagramm zur Erläuterung des Prozesses ist unten dargestellt -
Erstellen Sie eine Rolle mit den erforderlichen Berechtigungen
Gehen Sie zur AWS-Konsole und erstellen Sie eine Rolle.
Erstellen Sie einen Datenstrom in Kinesis
Gehen Sie zur AWS-Konsole und erstellen Sie einen Datenstrom in Kinesis.
Es gibt 4 Optionen wie gezeigt. In diesem Beispiel werden wir an Datenstrom erstellen arbeiten.
Klicken Create data stream. Geben Sie den Namen in den unten angegebenen Kinesis-Stream-Namen ein.
Geben Sie die Anzahl der Shards für den Datenstrom ein.
Die Details von Shards sind wie folgt:
Geben Sie den Namen ein und klicken Sie auf Create Kinesis stream Schaltfläche unten.
Beachten Sie, dass es eine gewisse Zeit dauert, bis der Stream aktiv wird.
Erstellen Sie eine AWS Lambda-Funktion
Gehen Sie zur AWS-Konsole und klicken Sie auf Lambda. Erstellen Sie die AWS Lambda-Funktion wie gezeigt -
Klicken Create functionSchaltfläche am Ende des Bildschirms. Fügen Sie Kinesis als Auslöser zu AWS Lambda hinzu.
Konfigurationsdetails zum Kinesis-Trigger hinzufügen -
Fügen Sie den Trigger hinzu und fügen Sie nun Code zu AWS Lambda hinzu.
Hinzufügen von Code zu AWS Lambda
Zu diesem Zweck verwenden wir nodejs als Laufzeit. Wir werden E-Mails senden, sobald AWS Lambda mit dem Kinesis-Datenstrom ausgelöst wird.
const aws = require("aws-sdk");
var ses = new aws.SES({
region: 'us-east-1'
});
exports.handler = function(event, context, callback) {
let payload = "";
event.Records.forEach(function(record) {
// Kinesis data is base64 encoded so decode here
payload = new Buffer(record.kinesis.data, 'base64').toString('ascii');
console.log('Decoded payload:', payload);
});
var eParams = {
Destination: {
ToAddresses: ["[email protected]"]
},
Message: {
Body: {
Text: {
Data:payload
}
},
Subject: {
Data: "Kinesis data stream"
}
},
Source: "[email protected]"
};
var email = ses.sendEmail(eParams, function(err, data) {
if (err) console.log(err);
else {
console.log("===EMAIL SENT===");
console.log("EMAIL CODE END");
console.log('EMAIL: ', email);
context.succeed(event);
callback(null, "email is send");
}
});
};
Der Ereignisparameter hat die Daten in den Kinesis-Datenstrom eingegeben. Der obige aws-Lambda-Code wird aktiviert, sobald Daten in den Kinesis-Datenstrom eingegeben wurden.
Hinzufügen von Daten zum Kinesis-Datenstrom
Hier verwenden wir AWS CLI, um den Datenkinesis-Datenstrom wie unten gezeigt hinzuzufügen. Zu diesem Zweck können wir den folgenden Befehl verwenden:
aws kinesis put-record --stream-name kinesisdemo --data "hello world" --
partition-key "789675"
Dann wird AWS Lambda aktiviert und die Mail gesendet.