Amazon Kinesis के साथ लैम्ब्डा फंक्शन का उपयोग करना

AWS Kinesisसेवा का उपयोग वेबसाइट क्लिक्स, लॉग्स, सोशल मीडिया फीड से आने वाले डेटा पर नज़र रखने / स्टोर करने के लिए किया जाता है। हम इस लॉग पर अतिरिक्त संसाधन करने के लिए AWS लैम्ब्डा को ट्रिगर कर सकते हैं।

आवश्यक वस्तुएँ

Kinesis और AWS लैम्ब्डा के साथ आरंभ करने के लिए बुनियादी आवश्यकताएं निम्नानुसार हैं -

  • आवश्यक अनुमतियों के साथ भूमिका बनाएँ
  • Kinesis में डेटा स्ट्रीम बनाएँ
  • AWS लाम्बा फ़ंक्शन बनाएं।
  • AWS लैम्ब्डा में कोड जोड़ें
  • Kinesis डेटा स्ट्रीम में डेटा जोड़ें

उदाहरण

आइए एक उदाहरण पर काम करते हैं जिसमें हम Kinesis से डेटा स्ट्रीम को संसाधित करने के लिए AWS लैम्ब्डा को ट्रिगर करेंगे और प्राप्त डेटा के साथ मेल भेजेंगे।

प्रक्रिया को समझाने के लिए एक सरल ब्लॉक आरेख नीचे दिखाया गया है -

आवश्यक अनुमतियों के साथ भूमिका बनाएँ

AWS कंसोल पर जाएं और एक भूमिका बनाएं।

Kinesis में डेटा स्ट्रीम बनाएँ

AWS कंसोल पर जाएं और kinesis में डेटा स्ट्रीम बनाएं।

दिखाए गए अनुसार 4 विकल्प हैं। हम इस उदाहरण में क्रिएट डेटा स्ट्रीम पर काम करेंगे।

क्लिक Create data stream। नीचे दिए गए Kinesis स्ट्रीम नाम में नाम दर्ज करें।

डेटा स्ट्रीम के लिए शार्क की संख्या दर्ज करें।

शार्द का विवरण नीचे दिया गया है -

नाम दर्ज करें और क्लिक करें Create Kinesis stream सबसे नीचे बटन।

ध्यान दें कि धारा को सक्रिय होने में निश्चित समय लगता है।

AWS लाम्बा फंक्शन बनाएं

AWS कंसोल पर जाएं और लैम्ब्डा पर क्लिक करें। दिखाए अनुसार AWS लाम्बा फ़ंक्शन बनाएं -

क्लिक Create functionस्क्रीन के अंत में बटन। AWS लैम्ब्डा के लिए ट्रिगर के रूप में Kinesis जोड़ें।

Kinesis ट्रिगर में कॉन्फ़िगरेशन विवरण जोड़ें -

ट्रिगर जोड़ें और अब AWS लैम्ब्डा में कोड जोड़ें।

AWS लैम्ब्डा में कोड जोड़ना

इस उद्देश्य के लिए, हम रन-टाइम के रूप में नोडज का उपयोग करेंगे। एक बार जब एडब्ल्यूएस लैंबडा को काइनिस डेटा स्ट्रीम के साथ ट्रिगर किया जाएगा तो हम मेल भेजेंगे।

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: ["[email protected]"]
      },
      Message: {
         Body: {
            Text: {
               Data:payload
            }
         },
         Subject: {
            Data: "Kinesis data stream"
         }
      },
      Source: "[email protected]"
   };    
   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");
      }
   });
};

ईवेंट परम में कीनेसिस डेटा स्ट्रीम में दर्ज किया गया डेटा है। Kinesis डेटा स्ट्रीम में डेटा दर्ज करने के बाद उपरोक्त aws lambda कोड सक्रिय हो जाएगा।

Kinesis डेटा स्ट्रीम में डेटा जोड़ें

यहाँ हम AWS CLI का उपयोग डेटा kinesis डेटा स्ट्रीम जोड़ने के लिए करेंगे जैसा कि नीचे दिखाया गया है। इस उद्देश्य के लिए, हम निम्नलिखित कमांड का उपयोग कर सकते हैं -

aws kinesis put-record --stream-name kinesisdemo  --data "hello world" --
partition-key "789675"

फिर, AWS लैम्ब्डा को सक्रिय किया जाता है और मेल भेजा जाता है।