- AWS Lambda - Additional Example
- Monitoring and TroubleShooting using Cloudwatch
- AWS Lambda@Edge with CloudFront
- Lambda Function with Custom User Applications
- Lambda Function with Amazon Kinesis
- Lambda Function with CloudTrail
- Lambda Function with Amazon SNS
- Lambda Function with Scheduled Events
- Lambda Function with Amazon DynamoDB
- Lambda Function with Amazon S3
- Working with Amazon API Gateway
- Deleting Lambda Function
- AWS Executing & Invoking Lambda Function
- Creating & Deploying using Serverless Framework
- Creating & Deploying using AWS CLI
- Creating & Deploying using AWS Console
- Configuring Lambda Function
- Function in C#
- Function in Go
- Function in Python
- Function in Java
- Function in NODEJS
- Building the Lambda function
- AWS Lambda - Introduction
- AWS Lambda - Environment Setup
- AWS Lambda - Overview
- AWS Lambda - Home
AWS Lambda Useful resources
Selected Reading
- Who is Who
- Computer Glossary
- HR Interview Questions
- Effective Resume Writing
- Questions and Answers
- UPSC IAS Exams Notes
Using Lambda Function with Amazon Kinesis
AWS Kinesis service is used to capture/store real time tracking data coming from website cpcks, logs, social media feeds. We can trigger AWS Lambda to perform additional processing on this logs.
Requisites
The basic requirements to get started with Kinesis and AWS Lambda are as shown −
Create role with required permissions
Create data stream in Kinesis
Create AWS Lambda function.
Add code to AWS Lambda
Add data to Kinesis data stream
Example
Let us work on an example wherein we will trigger AWS Lambda for processing the data stream from Kinesis and send mail with the data received.
A simple block diagram for explaining the process is shown below −
data:image/s3,"s3://crabby-images/975b8/975b82c7790b1d47d2ed79603c757e9473c8f932" alt="Block Diagram Kinesis"
Create Role with Required Permissions
Go to AWS console and create a role.
data:image/s3,"s3://crabby-images/ff578/ff578af05c74d2357669a33672ab000de1f7c595" alt="Required Permissions"
Create Data Stream in Kinesis
Go to AWS console and create data stream in kinesis.
data:image/s3,"s3://crabby-images/dbb90/dbb9022186a0b77febfbebc9132011de5316ffed" alt="Data Stream"
There are 4 options as shown. We will work on Create data stream in this example.
data:image/s3,"s3://crabby-images/3a44f/3a44faebe2d6ff1718f5f089894cbb4ffcc91a80" alt="Create Data Stream"
Cpck Create data stream. Enter the name in Kinesis stream name given below.
data:image/s3,"s3://crabby-images/94fdd/94fdd306c04a0f333d9fc89b40585fdacf8838d5" alt="Create Kinesis Stream"
Enter number of shards for the data stream.
data:image/s3,"s3://crabby-images/6f965/6f965f34f09b9ad6310fd726c2f6ac0c7f746d65" alt="Estimate Number"
The details of Shards are as shown below −
data:image/s3,"s3://crabby-images/e1455/e145555d3876b824692cd2732087ef27d1b0b446" alt="Shards"
Enter the name and cpck the Create Kinesis stream button at the bottom.
data:image/s3,"s3://crabby-images/b9086/b90861f3175d8eeaa49a278c36b064429a3c2aa7" alt="Kinesis Stream"
Note that it takes certain time for the stream to go active.
Create AWS Lambda Function
Go to AWS console and cpck Lambda. Create AWS Lambda function as shown −
data:image/s3,"s3://crabby-images/f2a78/f2a78238cdadfc0cf908cb426eb07e58bf212519" alt="Kinesis Lambda"
Cpck Create function button at the end of the screen. Add Kinesis as the trigger to AWS Lambda.
data:image/s3,"s3://crabby-images/31f3a/31f3ace6c08ca2caf653c9490206da08bb0498df" alt="Kinesis Trigger"
Add configuration details to the Kinesis trigger −
data:image/s3,"s3://crabby-images/cbed9/cbed90af71e9eb67bf178122448f34a3a34a2ade" alt="Configure Kinesis"
Add the trigger and now add code to AWS Lambda.
Adding Code to AWS Lambda
For this purpose, we will use nodejs as the run-time. We will send mail once AWS Lambda is triggered with kinesis data stream.
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: ["xxxxxxx@gmail.com"] }, Message: { Body: { Text: { Data:payload } }, Subject: { Data: "Kinesis data stream" } }, Source: "cxxxxxxxxx@gmail.com" }; 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"); } }); };
The event param has the data entered in kinesis data stream. The above aws lambda code will get activated once data is entered in kinesis data stream.
Add Data to Kinesis Data Stream
Here we will use AWS CLI to add data kinesis data stream as shown below. For this purpose, we can use the following command −
aws kinesis put-record --stream-name kinesisdemo --data "hello world" -- partition-key "789675"
data:image/s3,"s3://crabby-images/d14ea/d14ea63d6e8ccce81f2f9f8a72ed73e908d4a5c9" alt="Data Kinesis"
Then, AWS Lambda is activated and the mail is sent.
data:image/s3,"s3://crabby-images/f3b5d/f3b5d34970cfeaea728f8086c53f86095a9a50b3" alt="Activate Mail"
data:image/s3,"s3://crabby-images/8cd81/8cd81a30d6c8abc160000d5d4a736957864fcf86" alt="Kinesis Command"
data:image/s3,"s3://crabby-images/ab4cc/ab4cc1744ffcee16e52b2b04b5ebbca39f771a10" alt="Kinesis Mail"