कस्टम उपयोगकर्ता अनुप्रयोगों के साथ लैम्ब्डा फ़ंक्शन का उपयोग करना
हम निम्नलिखित दो तरीकों से उपयोगकर्ता के आवेदन द्वारा उत्पन्न घटनाओं का उपयोग करने के लिए 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