AWS लाम्बा - NODEJS में कार्य

Nodejs उन भाषाओं में से एक है जो AWS लाम्बा फ़ंक्शन का समर्थन करती है। नोडज के साथ समर्थित संस्करण v6.10 और v8.10 हैं। इस अध्याय में, हम NODEJS में AWS लाम्बा समारोह की विभिन्न क्रियाओं के बारे में विस्तार से जानेंगे।

NodeJS में हैंडलर

नोडज में लैंबडा फ़ंक्शन लिखने के लिए, हमें पहले एक हैंडलर की घोषणा करनी चाहिए। नोडज में हैंडलर फ़ाइल का नाम और निर्यात फ़ंक्शन का नाम है। उदाहरण के लिए, फ़ाइल का नाम हैindex.js और निर्यात समारोह का नाम है lambda handler, इसलिए इसका संगत हैंडलर है index.lambdahandler

यहां दिखाए गए एक नमूना हैंडलर का निरीक्षण करें -

exports.lambdahandler = function(event, context, callback) {   //code goes here}

परमर्स टू हैंडलर

लैम्ब्डा फ़ंक्शन के निर्माण के लिए हैंडलर मुख्य कोर है। हैंडलर को तीन पाराम लगते हैं:event, context तथा callback

इवेंट पैरामीटर

इसमें ट्रिगर किए गए ईवेंट के सभी विवरण हैं। उदाहरण के लिए, यदि हम S3 पर चालू होने के लिए लैंबडा फ़ंक्शन का उपयोग कर रहे हैं, तो घटना में S3 ऑब्जेक्ट का विवरण होगा।

संदर्भ पैरामीटर

इसमें लैंबडा फ़ंक्शन के गुण और कॉन्फ़िगरेशन विवरण जैसे संदर्भ का विवरण है।

कॉलबैक फ़ंक्शन

यह कॉलर को वापस विवरण देने में मदद करता है। कॉलबैक की संरचना इस प्रकार है -

callback(error, result);

कॉलबैक फ़ंक्शन के मापदंडों को नीचे दिया गया है -

Error −इसमें यह विवरण होगा कि लैम्बडा फ़ंक्शन के निष्पादन के दौरान कोई त्रुटि हुई है या नहीं। यदि लैम्ब्डा फ़ंक्शन सफल होता है,null कॉलबैक फ़ंक्शन के लिए पहले परम के रूप में पारित किया जा सकता है।

Result −यह लैम्ब्डा फ़ंक्शन के सफल निष्पादन का विवरण देगा। यदि कोई त्रुटि होती है, तो परिणाम को नजरअंदाज कर दिया जाता है।

Note −AWS लैम्ब्डा में कॉलबैक फ़ंक्शन का उपयोग करना अनिवार्य नहीं है। यदि कोई कॉलबैक फ़ंक्शन नहीं है, तो इसे बंद करें, हैंडलर इसे अशक्त के रूप में वापस कर देगा।

मान्य कॉलबैक हस्ताक्षर नीचे दिए गए हैं -

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

जब भी AWS लैम्ब्डा को कॉलबैक विवरण जैसे कि त्रुटि या सफलता मिलती है, एडब्ल्यूएस क्लाउडवॉच में सांत्वना संदेशों के साथ लॉग इन किया जाता है, यदि कोई हो।

Nodejs8.10 में AWS लैम्ब्डा के साथ काम करना

आइए समझते हैं कि नोड्स 8 में AWS लैम्ब्डा के साथ कैसे काम करें और सिंक और एसिंक्स तरीके से फ़ंक्शन को लागू करें।

सिंक वे में लैंबडा फंक्शन को आमंत्रित करना

निम्नलिखित उदाहरण आपको सिंक प्रकार से लैम्ब्डा फ़ंक्शन को लागू करने के बारे में एक विचार देता है -

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);
};

AWS कंसोल में इस कोड का परीक्षण करने के बाद आप निम्नलिखित आउटपुट देख सकते हैं -

ध्यान दें कि उपरोक्त कोड से आउटपुट एक वादा वस्तु है। यह गिनती नहीं देता है, क्योंकि एक सेटटाइमआउट के अंदर गिनती बढ़ाई जाती है और फ़ंक्शन कॉल सेटटाइमआउट के अंदर निष्पादन के लिए इंतजार नहीं करता है और वादा वस्तु लौटाता है।

अगर हमारे पास होता तो async/await हैंडलर फ़ंक्शन पर लैम्बडा फ़ंक्शन से सटीक आउटपुट प्राप्त होगा।

एक Async रास्ते में हैंडलर का आह्वान

निम्नलिखित उदाहरण आपको एक अलंकृत तरीके से लैम्ब्डा फ़ंक्शन को लागू करने के बारे में एक विचार देता है -

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);
};

हमने जोड़ा है async तथा awaitउपरोक्त कोड में। जब हम उपयोग करते हैंawaitफ़ंक्शन कॉल के पास, निष्पादन तब तक रुक जाता है जब तक कि फ़ंक्शन के अंदर का वादा हल नहीं हो जाता है। ध्यान दें किawait के लिए ही मान्य है async कार्य करता है।

AWS कंसोल में इस कोड का परीक्षण करने के बाद आप निम्नलिखित आउटपुट देख सकते हैं -

NodeJS में ContextDetails

प्रसंग वस्तु विवरण देता है जैसे कि लैम्ब्डा फ़ंक्शन का नाम, मिलीसेकंड में शेष समय, अनुरोध आईडी, क्लाउडवॉच समूह का नाम, टाइमआउट विवरण आदि।

निम्न तालिका संदर्भ वस्तु के साथ उपलब्ध तरीकों और विशेषताओं की सूची को दिखाती है -

संदर्भ वस्तु के लिए उपलब्ध विधि

अनु क्रमांक विधि का नाम और विवरण
1

getRemainingTimeInMillis()

यह विधि मिलीसेकंड में शेष समय तब तक देती है जब तक लैंबडा फ़ंक्शन फ़ंक्शन को समाप्त नहीं करता है

संदर्भ वस्तु के लिए उपलब्ध गुण

अनु क्रमांक विशेषता नाम और विवरण
1

functionName

यह AWS लैम्ब्डा फ़ंक्शन नाम देता है

2

functionVersion

यह AWS लैम्ब्डा फंक्शन को अंजाम देने का वर्जन देता है

3

nvokedFunctionArn

यह ARN विवरण देगा।

4

memoryLimitInMB

यह लैंबडा फ़ंक्शन बनाते समय जोड़ी गई मेमोरी सीमा को दर्शाता है

5

awsRequestId

यह AWS अनुरोध आईडी देता है।

6

logGroupName

यह क्लाउडवॉच समूह के नाम का नाम देगा

7

logStreamName

यह क्लाउडवॉच लॉग स्ट्रीम नाम देगा जहां लॉग लिखे गए हैं।

8

identity

यह amazon cognito आइडेंटिटी प्रोवाइडर के बारे में डिटेल्स देगा जब aws mobile sdk के साथ प्रयोग किया जाएगा।

दिए गए विवरण इस प्रकार हैं -

  • identity.cognito_identity_id
  • identity.cognito_identity_pool_id
9

clientContext

यह क्लाइंट एप्लिकेशन का विवरण देगा जब इसका उपयोग मोबाइल sdk के साथ किया जाएगा। दिए गए विवरण इस प्रकार हैं -

  • client_context.client.installation_id
  • client_context.client.app_title
  • client_context.client.app_version_name
  • client_context.client.app_version_code
  • client_context.client.app_package_name
  • client_context.custom - इसमें मोबाइल क्लाइंट ऐप से कस्टम मानों का ताना-बाना है
  • client_context.env - इसमें AWS मोबाइल SDK से पर्यावरण विवरण है

संदर्भ वस्तु के बारे में बेहतर विचार प्राप्त करने के लिए निम्नलिखित उदाहरण देखें -

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);
};

AWS कंसोल में इस कोड का परीक्षण करने के बाद आप निम्नलिखित आउटपुट देख सकते हैं -

AWS कंसोल में इस कोड का परीक्षण करने के बाद आप निम्न लॉग आउटपुट का अवलोकन कर सकते हैं -

NodeJS में लॉगिंग

हम NodeJS में लॉगिंग के लिए कंसोल.लॉग का उपयोग कर सकते हैं। लैंबडा फ़ंक्शन के खिलाफ लॉग-इन विवरण क्लाउडवॉच सेवा से प्राप्त किया जा सकता है।

एक बेहतर समझ के लिए निम्न उदाहरण देखें -

exports.handler = (event, context, callback) => {
   // TODO implement
   console.log('Logging for AWS Lamnda in NodeJS');
   callback(null, 'Name of aws Lambda is=>'+context.functionName);
};

AWS कंसोल में इस कोड का परीक्षण करने के बाद आप निम्नलिखित आउटपुट देख सकते हैं -

आप CloudWatch से निम्न स्क्रीनशॉट देख सकते हैं -

NodeJS में त्रुटि हैंडलिंग

आइए समझते हैं कि NodeJS में एरर नोटिफिकेशन कैसे होता है। निम्नलिखित कोड देखें -

exports.handler = function(event, context, callback) {
   // This Source code only throws error. 
   var error = new Error("something is wrong");
   callback(error);   
};

आप लॉग आउटपुट में निम्नलिखित को देख सकते हैं -

त्रुटि विवरण कॉलबैक में दिए गए हैं: -

{
   "errorMessage": "something is wrong",
   "errorType": "Error",
   "stackTrace": [    "exports.handler (/var/task/index.js:2:17)"  ]
}