Menggunakan Fungsi Lambda dengan Amazon Kinesis
AWS Kinesislayanan digunakan untuk menangkap / menyimpan data pelacakan waktu nyata yang berasal dari klik situs web, log, umpan media sosial. Kami dapat memicu AWS Lambda untuk melakukan pemrosesan tambahan pada log ini.
Persyaratan
Persyaratan dasar untuk memulai Kinesis dan AWS Lambda seperti yang ditunjukkan -
- Buat peran dengan izin yang diperlukan
- Buat aliran data di Kinesis
- Buat fungsi AWS Lambda.
- Tambahkan kode ke AWS Lambda
- Tambahkan data ke aliran data Kinesis
Contoh
Mari kita kerjakan contoh di mana kita akan memicu AWS Lambda untuk memproses aliran data dari Kinesis dan mengirim email dengan data yang diterima.
Diagram blok sederhana untuk menjelaskan prosesnya ditunjukkan di bawah ini -
Buat Peran dengan Izin yang Diperlukan
Buka konsol AWS dan buat peran.
Buat Aliran Data di Kinesis
Buka konsol AWS dan buat aliran data di kinesis.
Ada 4 opsi seperti yang ditunjukkan. Kami akan mengerjakan Buat aliran data dalam contoh ini.
Klik Create data stream. Masukkan nama dalam nama aliran Kinesis yang diberikan di bawah ini.
Masukkan jumlah pecahan untuk aliran data.
Rincian Pecahan seperti yang ditunjukkan di bawah ini -
Masukkan nama dan klik Create Kinesis stream tombol di bagian bawah.
Perhatikan bahwa perlu waktu tertentu agar streaming menjadi aktif.
Buat Fungsi AWS Lambda
Buka konsol AWS dan klik Lambda. Buat fungsi AWS Lambda seperti yang ditunjukkan -
Klik Create functiontombol di ujung layar. Tambahkan Kinesis sebagai pemicu ke AWS Lambda.
Tambahkan detail konfigurasi ke pemicu Kinesis -
Tambahkan pemicu dan sekarang tambahkan kode ke AWS Lambda.
Menambahkan Kode ke AWS Lambda
Untuk tujuan ini, kami akan menggunakan nodejs sebagai run-time. Kami akan mengirim email setelah AWS Lambda dipicu dengan aliran data kinesis.
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");
}
});
};
Parameter acara memiliki data yang dimasukkan dalam aliran data kinesis. Kode lambda aws di atas akan diaktifkan setelah data dimasukkan dalam aliran data kinesis.
Tambahkan Data ke Kinesis Data Stream
Disini kita akan menggunakan AWS CLI untuk menambahkan data kinesis data stream seperti gambar dibawah ini. Untuk tujuan ini, kita dapat menggunakan perintah berikut -
aws kinesis put-record --stream-name kinesisdemo --data "hello world" --
partition-key "789675"
Kemudian, AWS Lambda diaktifkan dan email dikirim.