कस्टम उपयोगकर्ता अनुप्रयोगों के साथ लैम्ब्डा फ़ंक्शन का उपयोग करना

हम निम्नलिखित दो तरीकों से उपयोगकर्ता के आवेदन द्वारा उत्पन्न घटनाओं का उपयोग करने के लिए AWS लैम्ब्डा फ़ंक्शन का उपयोग कर सकते हैं -

  • AWS कंसोल का उपयोग करना
  • AWS सीएलआई का उपयोग करना

AWS कंसोल का उपयोग करना

AWS कंसोल से, हम घटनाओं और AWS लैम्ब्डा के साथ काम करेंगे। इस उद्देश्य के लिए, AWS कंसोल पर जाएं और एक लैम्ब्डा फ़ंक्शन बनाएं।

अगला, AWS लैम्ब्डा के लिए कोड जोड़ें -

exports.handler = (event, context, callback) => {
   // TODO implement
   console.log("Hello => "+ event.name);
   console.log("Address =>"+ event.addr);
   callback(null, 'Hello '+event.name +" and address is "+ event.addr);
};

ध्यान दें कि उपरोक्त कोड में, हम घटना का उपयोग करके नाम और पता प्रिंट कर रहे हैं।

इस घटना का विवरण निम्नानुसार बनाए गए परीक्षण कार्यक्रम का उपयोग करके दिया जाएगा -

अब, घटना को बचाएं और उसका परीक्षण करें।

इसी लॉग आउटपुट को यहाँ दिखाया गया है -

AWS सीएलआई का उपयोग करना

हम AWS CLI का उपयोग करके उपरोक्त फ़ंक्शन को निम्नानुसार शुरू कर सकते हैं -

aws lambda invoke --function-name "lambdauserevent" --log-type Tail --
payload file://C:\clioutput\input.txt C:\clioutput\outputfile.txt

घटना का विवरण पेलोड को दिया जाता है और आउटपुट को स्टोर किया जाता है C:\clioutput\outputfile.txt. निम्नानुसार है -

input.txt

{"name":"Roy Singh", "addr":"Mumbai"}

AWS सीएलआई का उपयोग करके लैम्ब्डा का उपयोग करने पर, आप देख सकते हैं कि आउटपुट निम्नानुसार है -

इसी तरह, यदि आप किसी अन्य AWS सेवा के लिए AWS लैम्ब्डा का परीक्षण करना चाहते हैं, तो आप AWS कंसोल और AWS CLI में परीक्षण घटना का उपयोग करके ऐसा कर सकते हैं। एसएनएस सेवा के लिए एक नमूना कार्यक्रम नीचे दिखाया गया है -

{
   "Records": [{
      "EventVersion": "1.0",
      "EventSubscriptionArn": "arnid",
      "EventSource": "aws:sns",
      "Sns": {
         "SignatureVersion": "1",
         "Timestamp": "1970-01-01T00:00:00.000Z",
         "Signature": "EXAMPLE",
         "SigningCertUrl": "EXAMPLE",
         "MessageId": "95df01b4-ee98-5cb9-9903-4c221d41eb5e",
         "Message": "Hello from SNS!",
         "MessageAttributes": {
            "Test": {
               "Type": "String",
               "Value": "TestString"
            },
            "TestBinary": {
               "Type": "Binary",
               "Value": "TestBinary"
            }
         },
         "Type": "Notification",
         "UnsubscribeUrl": "EXAMPLE",
         "TopicArn": "topicarn",
         "Subject": "TestInvoke"
      }
   }]
}

आइए हम ऊपर दिखाए गए नमूना घटना को जोड़ते हैं और इसे दिखाए अनुसार परीक्षण करते हैं -

एडब्ल्यूएस लाम्बा में, कोड एसएनएस संदेश को प्रिंट करेगा जैसा कि नीचे दिए गए उदाहरण में दिखाया गया है -

exports.handler = (event, context, callback) => {
   // TODO implement
   console.log(event.Records[0].Sns.Message);
   callback(null, event.Records[0].Sns.Message);};

आइए हम AWS CLI का उपयोग करके इसे लागू करते हैं। आइए हम एक फ़ाइल में ईवेंट को सहेजते हैं और दिखाए गए कमांड का उपयोग करके पेलोड के लिए उपयोग करते हैं -

aws lambda invoke --function-name "lambdauserevent" --log-type Tail --
payload file://C:\clioutput\sns.txt C:\clioutput\snsoutput.txt