AWS कंसोल का उपयोग करके निर्माण और तैनाती
हम लैम्ब्डा फ़ंक्शन बना सकते हैं और एडब्ल्यूएस कंसोल में उसी का परीक्षण कर सकते हैं। इस अध्याय में इस पर विस्तार से चर्चा की गई है। इस उद्देश्य के लिए, आपको यहां दिए गए चरणों का पालन करना होगा और दिए गए संबंधित स्क्रीनशॉट का अवलोकन करना होगा -
चरण 1
AWS कंसोल में लॉगिन करें https://aws.amazon.com/console/। अब, आपको उस स्क्रीन पर पुनर्निर्देशित किया जाएगा जहां AWS सेवाएँ प्रदर्शित हैं।
चरण 2
अब, पर क्लिक करें Lambdaजैसा कि ऊपर बताया गया है। यह नीचे दिखाए अनुसार फ़ंक्शन बनाने के लिए रीडायरेक्ट करेगा -
चरण 3
अब, क्लिक करें Create functionऔर फ़ंक्शन का विवरण दर्ज करें। फिर आप नीचे दिखाए अनुसार एक स्क्रीन देख सकते हैं -
चरण 4
आप अपनी पसंद की भाषा चुनकर अपना कोड लिख सकते हैं। कोड को संपादक में लिखा जाना चाहिए, यदि चयनित विकल्प कोड इनलाइन को संपादित करता है। उपलब्ध अन्य विकल्प इस प्रकार हैं -
चरण 5
एक बार आपको उन परिवर्तनों को सहेजने की आवश्यकता होती है, जिनके लिए नीचे दाएं कोने में बटन दिया गया है -
चरण 6
अब, क्लिक करें Testबटन। यह लैम्ब्डा फ़ंक्शन के निष्पादन के सभी विवरण नीचे दिए गए अनुसार दिया गया है -
चरण 7
के लिए कोड index.js इस प्रकार है -
exports.handler = (event, context, callback) => {
// TODO implement
callback(null, 'Lambda test');
};
यह कॉल करेगा Callback functionऔर परिणाम त्रुटि या सफलता हो सकती है। सफलता पर आप देखेंगेLambda testसंदेश; यदि त्रुटि है तो यह अशक्त हो जाएगा।
चरण 8
Role लैंबडा फ़ंक्शन का विवरण कॉन्फ़िगरेशन का एक हिस्सा है और नीचे दिखाए अनुसार प्रदर्शित किया जाता है -
चरण 9
अब, यदि आवश्यक हो तो आप भूमिका को अपडेट कर सकते हैं और लैम्ब्डा फ़ंक्शन को बचा सकते हैं। फिर, मेमने और समारोह के लिए मध्यांतर का विवरण नीचे दिखाया गया है -
चरण 10
अब, हमें लैम्बडा फ़ंक्शन में ट्रिगर जोड़ने की आवश्यकता है ताकि यह घटना होने पर निष्पादित हो। ट्रिगर विवरण एडब्ल्यूएस लैंबडा फंक्शन स्क्रीन के शुरू में प्रदर्शित होते हैं जैसा कि नीचे दिखाया गया है -
इससे, आप ट्रिगर का चयन कर सकते हैं जो आप चाहते हैं कि आपका लैम्बडा फ़ंक्शन ट्रिगर हो जाए। जब आप ट्रिगर का चयन करते हैं, तो ट्रिगर के लिए कॉन्फ़िगर विवरण को जोड़ना होगा।
उदाहरण के लिए, S3 पर ट्रिगर के लिए जोड़े जाने वाले विन्यास विवरण इस प्रकार हैं -
चरण 11
अब, उस बाल्टी का चयन करें जिसे आप ट्रिगर चाहते हैं। घटना के प्रकार में निम्नलिखित विवरण हैं -
चरण 12
ट्रिगर के लिए, आप उपसर्ग प्रकार की फाइलों या फ़ाइल पैटर्न का भी उल्लेख कर सकते हैं, लैम्बडा को ट्रिगर करना होगा। विवरण निम्नानुसार हैं -
चरण 13
अब, ट्रिगर के लिए आवश्यक विवरण भरें और क्लिक करें Add बटन। ट्रिगर को जोड़ने के लिए लैम्ब्डा फ़ंक्शन को मिलाएं। फ़ंक्शन के विवरण को दर्शाते हुए, और अब से कभी भी फाइलें एस 3 बाल्टी में जोड़ दी जाती हैं, लैम्बडा ट्रिगर हो जाएगा।
निम्नलिखित स्क्रीनशॉट को ध्यान से देखें जो S3 ट्रिगर को AWS लैंबडा में जोड़ा गया है -
चरण 14
अब, हम लैम्ब्डा फ़ंक्शन का परीक्षण करने के लिए S3 नमूना इवेंट का उपयोग करते हैं। उसी के लिए कोड यहाँ दिखाया गया है -
अमेज़ॅन एस 3 पुट सैंपल इवेंट
{
"Records": [{
"eventVersion": "2.0",
"eventTime": "1970-01-01T00:00:00.000Z",
"requestParameters": {
"ExampleIPAddress": "127.0.0.1"
},
"s3": {
"configurationId": "testConfigRule",
"object": {
"eTag": "0123456789abcdef0123456789abcdef",
"sequencer": "0A1B2C3D4E5F678901",
"key": "HappyFace.jpg",
"size": 1024
},
"bucket": {
"arn": bucketarn,
"name": "Examplebucket",
"ownerIdentity": {
"principalId": "Example"
}
},
"s3SchemaVersion": "1.0"
},
"responseElements": {
"x-amz-id-2": "Example123/5678abcdefghijklambdaisawesome/mnopqrstuvwxyzABCDEFGH",
"x-amz-request-id": "Example123456789"
},
"awsRegion": "us-east-1",
"eventName": "ObjectCreated:Put",
"userIdentity": {
"principalId": "Example"
},
"eventSource": "aws:s3"
}]
}
S3 put इवेंट से अपलोड की गई फ़ाइल का विवरण प्राप्त करने के लिए आपको निम्नलिखित कमांड का उपयोग करना होगा -
event.Records[0].s3.object.key //will display the name of the file
बाल्टी नाम पाने के लिए आपको निम्न कमांड का उपयोग करना होगा -
event.Records[0].s3.bucket.name //will give the name of the bucket.
EventName प्राप्त करने के लिए आपको निम्न कमांड का उपयोग करना होगा -
event.Records[0].eventName // will display the event name
चरण 15
अब, नीचे दिखाए गए अनुसार S3 विवरण प्रिंट करने के लिए AWS लैम्ब्डा कोड अपडेट करें -
exports.lambdahandler = (event, context, callback) => {
callback(null, "Bucket name: "+event.Records[0].s3.bucket.name+"
File name:"+event.Records[0].s3.object.key );
};
चरण 16
परिवर्तनों को सुरक्षित करें। क्लिक करेंTest और S3 नमूना घटना दर्ज करें -
चरण 17
अब क्लिक करें Test और आप आउटपुट को देख सकते हैं -
चरण 18
S3 AWS सेवा का उपयोग करके S3 पर ट्रिगर का परीक्षण करने के लिए, S3 बाल्टी में एक फ़ाइल अपलोड करें: test bucket trigger। अनुमतियों के लिए S3 और SES नीति (मेल भेजने के लिए) लेम्बडा के साथ उपयोग की जाने वाली भूमिका को अपडेट करें। यह ट्रिगर काम करने के लिए मेल भेजने के लिए AWS लैम्ब्डा कोड अपडेट करेगा -
अद्यतन AWS लैम्ब्डा कोड निम्नानुसार है -
var aws = require('aws-sdk');
var ses = new aws.SES({
region: 'us-east-1'
});
exports.lambdahandler = function(event, context, callback) {
var eParams = {
Destination: {
ToAddresses: ["coxxxxxxx@gmail.com"]
},
Message: {
Body: {
Text: {
Data: "Bucket name: "+event.Records[0].s3.bucket.name+" File name:"+event.Records[0].s3.object.key
}
},
Subject: {
Data: "S3 and AWS Lambda"
}
},
Example: "coxxxxxx@gmail.com"
};
console.log('===SENDING EMAIL===');
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");
}
});
};
इसी स्क्रीनशॉट को यहाँ दिखाया गया है -
चरण 19
अब, फ़ाइल अपलोड करें और AWS लैम्ब्डा कोड में दी गई मेल आईडी की जांच करें -