CloudFront के साथ AWS लैम्ब्डा @ एज का उपयोग करना
लैम्ब्डा @ एज एडब्ल्यूएस लैम्ब्डा कंप्यूट सेवा के अतिरिक्त है जो क्लाउडफ्रंट डिलीवर करने वाली सामग्री को अनुकूलित करने के लिए उपयोग किया जाता है।
ब्लॉक आरेख जो AWS से क्लाउडफ्रंट के साथ AWS लैम्ब्डा के कामकाज को दिखाता है -
ऐसे चार तरीके हैं जिनमें AWS लैम्ब्डा का उपयोग किया जा सकता है -
Viewer Request − अंतिम उपयोगकर्ता क्लाउडफ़ॉरेस्ट के लिए व्यूअर अनुरोध नामक अनुरोध करता है
Origin Request − CloudFront मूल के लिए अनुरोध आगे की ओर
Origin Response − CloudFront को मूल से प्रतिक्रिया मिलती है
Viewer Response − CloudFront दर्शक को प्रतिक्रिया भेजती है
हम निम्न उद्देश्यों के लिए लैम्ब्डा @ एज का उपयोग कर सकते हैं -
अनुरोध और प्रतिक्रिया समय पर हेडर बदलने के लिए।
हेडर में कुकीज़ विवरण जोड़ें। अनुरोध और प्रतिक्रिया के आधार पर एबी परीक्षण करें।
हेडर विवरण के आधार पर URL को किसी अन्य साइट पर पुनर्निर्देशित करें।
हम उपयोगकर्ता-एजेंट को हेडर से ला सकते हैं और ब्राउज़र, ओएस आदि के विवरण का पता लगा सकते हैं।
आवश्यक वस्तुएँ
CloudFront और Lambda @ Edge पर काम शुरू करने के लिए, हमें निम्नलिखित की आवश्यकता है -
फ़ाइल विवरण के साथ S3 भंडारण बाल्टी बनाएँ
ऐसी भूमिका बनाएं जो CloudFront और Lambda @ Edge के साथ काम करने की अनुमति देगा
CloudFront वितरण बनाएँ
लंबोदा फंक्शन बनाएं
क्लाउडफ्रंट में लैम्ब्डा फ़ंक्शन विवरण जोड़ें
ब्राउज़र में क्लाउडफ्रंट यूआरएल की जाँच करें
हम CloudFront और Lambda @ Egde के साथ एक उदाहरण पर काम करेंगे, जिसमें हम पृष्ठ की मेजबानी करेंगे और डेस्कटॉप और उपकरणों के रूप में पता चलने पर प्रतिक्रिया को बदल देंगे।
फ़ाइल विवरण के साथ S3 संग्रहण बाल्टी बनाएँ
AWS कंसोल में लॉगिन करें और S3 में एक बकेट बनाएं और जोड़ें . html फ़ाइल जिसे आप प्रदर्शित करना चाहते हैं।
पर क्लिक करें S3 तथा Create bucket जैसा कि नीचे दिखाया गया है -
अब, क्लिक करें Create bucket नीचे दिए गए अनुसार बटन और बाल्टी का विवरण जोड़ें -
पर क्लिक करें Create बटन और उसमें .html अपलोड करें।
भूमिका बनाएँ
AWS कंसोल पर जाएं और क्लिक करें IAM।
अब, क्लिक करें Roles -> Create role दिखाया गया बटन -
के लिए अनुमति चुनें S3, Lambda तथा Cloudfront। एआरएन विवरण का उपयोग करके केवल आवश्यक फ़ंक्शन, स्टोरेज को अनुमति देने वाली पॉलिसी बनाना एक अच्छा अभ्यास है।
नीचे दिए गए उदाहरण में, हम दिखा रहे हैं Full Accessअनुमति। भूमिका नाम के लिए नीतियांrole for cloudfrontजैसा कि ऊपर दिखाया गया है। क्रिएट भूमिका पर क्लिक करें।
लैम्ब्डा @ एज और क्लाउडफ्रंट के लिए आवश्यक सभी पॉलिसी ऊपर दिखाए गए हैं। यहाँ एक अतिरिक्त कदम उठाया जा सकता है क्योंकि क्लाउड के उरेल के बाद से पूरे क्षेत्र में url उपलब्ध होगा और इसे उन सेवाओं के बीच विश्वास संबंध की आवश्यकता है जिनका हम उपयोग कर रहे हैं।
अब, बनाई गई भूमिका के लिए, पर क्लिक करें Trust relationships दिखाया गया टैब -
पर क्लिक करें Edit Trust Relationship जैसा कि नीचे दिखाया गया है -
यह एक नीति दस्तावेज़ प्रदर्शित करता है। हमें अन्य सेवाओं को इसमें जोड़ना होगाPrincipal -> Serviceजिसे हम उपयोग करने की योजना बना रहे हैं। अंतिम विश्वास संबंध नीति दस्तावेज निम्नानुसार है -
क्लिक Update Trust Policy परिवर्तनों को सहेजने के लिए बटन।
CloudFront वितरण बनाएँ
नीचे दिखाए अनुसार CloudFront सेवा पर जाएं -
CloudFront सर्विस पर क्लिक करें और क्लिक करें Create Distribution -
उत्पत्ति सेटिंग्स, व्यवहार सेटिंग्स और वितरण सेटिंग्स
आइए हम इन सेटिंग्स को एक-एक करके देखते हैं -
Origin Settings
उत्पत्ति सेटिंग्स के विभिन्न मापदंडों को नीचे दिया गया है -
Origin Domain Name −यह S3 बाल्टी का नाम है जहां हमने html फाइलें संग्रहीत की हैं। हम अपनी पसंद के फ़ोल्डर्स बनाकर S3 बकेट में, यदि कोई हो, चित्र भी स्टोर कर सकते हैं।
Origin Path −यहां आपको उस फ़ोल्डर का नाम दर्ज करना होगा जहां फाइलें संग्रहीत हैं। वर्तमान में, हमारे पास यह फ़ोल्डर नहीं है, इसलिए हम इसे अभी के लिए खाली रखेंगे।
Origin ID −जब मूल डोमेन नाम का चयन किया जाता है तो यह आबाद हो जाता है। आप अपनी पसंद के अनुसार आईडी बदल सकते हैं।
Restrict Bucket Access − इसमें हम विकल्प चुनेंगे yes। यहां हमें S3 बाल्टी के लिए सुरक्षा की आवश्यकता है ताकि S3 बाल्टी तक किसी की पहुंच न हो। इस विकल्प के लिए कुछ और विकल्प हैं जैसे आबादीOrigin Access Identity, Comment and Grant Read Permission on Bucket।
Origin Access Identity −हमने एक नया पहचान विकल्प बनाया है। आप मौजूदा पहचान भी चुन सकते हैं। यह एक नई पहचान बनाता है जिसका उपयोग CloudFront द्वारा S3 बाल्टी से विवरण पढ़ने के लिए किया जाता है।
Grand Read Permission on Bucket − इसके लिए विकल्प चुनें Yes।
Origin Custom Headers − हम हेडर को यहाँ रिक्त रखेंगे, क्योंकि हमें अभी विवरण की आवश्यकता नहीं है।
इसके बाद, चर्चा करें और भरें Behaviour Settings क्लाउड वितरण के लिए -
अब, प्रोटोकॉल - https या http, और कैशिंग विकल्प चुनें। ध्यान दें कि डिफ़ॉल्ट कैशिंग 86400 या 24 घंटे है। आप आवश्यकता के अनुसार इस मान को बदल सकते हैं।
क्लिक Object Caching(अनुकूलित विकल्प) कैशिंग बदलने के लिए। आप उपयोग कर सकते हैंsmooth streamingअगर आपके पेज पर कोई वीडियो है तो। यहां, हम डिफ़ॉल्ट विकल्प उपलब्ध रख रहे हैं। एक बार लैम्ब्डा फ़ंक्शन बनाने के बाद, इसका विवरण जोड़ा जाएगा।
वितरण सेटिंग्स का विवरण नीचे दिखाया गया है -
वितरण सेटिंग्स के विभिन्न मापदंडों को नीचे समझाया गया है -
Price class −इसमें उपयोगकर्ताओं के आवागमन की उत्पत्ति जैसे विवरण हैं। ध्यान दें कि यहाँ हमने डिफ़ॉल्ट को चुना है -Use All Edge Locations.
AWS WAF Web ACL −यह वेब एप्लिकेशन फ़ायरवॉल चयन के लिए है। यहाँ, यह विकल्प के रूप में हैNone। सबसे पहले, हमें AWS में फ़ायरवॉल बनाने की आवश्यकता है। यह साइट को सुरक्षा प्रदान करता है।
Alternate Domain Names − यहां आप डोमेन नाम निर्दिष्ट कर सकते हैं यदि आपके पास है।
SSL Certificate −इसमें एसएसएल प्रमाणपत्र के लिए चुने जाने वाले सभी विवरण हैं। हम डिफॉल्ट को ही रखेंगे।
Default Root Object −यहां हम उस फ़ाइलनाम को निर्दिष्ट करेंगे जो हमने S3 में अपलोड किया है। इसके लिए, हमें डिफ़ॉल्ट रूप से प्रदर्शित करने के लिए .html से सामग्री की आवश्यकता होती है।
बाकी के लिए, हम डिफ़ॉल्ट सेटिंग रखेंगे।
क्लिक Create Distribution वितरण को जोड़ने के लिए बटन।
ध्यान दें कि वितरण को स्थिति के रूप में दिखाने के लिए कुछ समय लगेगा।
AWS लाम्बा फंक्शन बनाएं
AWS कंसोल पर जाएं और लैम्ब्डा फ़ंक्शन बनाएं।
AWS लैम्ब्डा कोड में, हम अनुरोध हेडर लेंगे और उपयोगकर्ता-एजेंट की जांच करेंगे। यदि उपयोगकर्ता-एजेंट डेस्कटॉप से है, तो हम संदेश को प्रदर्शित करने के लिए प्रतिक्रिया को बदल देंगे“DESKTOP : Welcome to AWS Lambda with Cloudfront!” और अगर डिवाइस संदेश होगा“MOBILE DEVICES : Hello from Lambda@Edge!”
संबंधित एडब्ल्यूएस लाम्बा कोड नीचे दिखाया गया है -
let content = `
<\!DOCTYPE html>
<html lang="en">
<head>
<meta charset="utf-8">
<title>Simple Lambda@Edge Static Content Response</title>
<meta name="viewport" content="width=device-width, initial-scale=1.0">
</head>
<body>
<h1>MOBILE DEVICES : Hello from Lambda@Edge!</h1>
</body>
</html>
`;
let content1 = `
<\!DOCTYPE html>
<html lang="en">
<head>
<meta charset="utf-8">
<title>Simple Lambda@Edge Static Content Response</title>
<meta name="viewport" content="width=device-width, initial-scale=1.0">
</head>
<body>
<h1>DESKTOP : Welcome to AWS Lambda with Cloudfront!</h1>
</body>
</html>
`;
exports.handler = (event, context, callback) => {
let request = event.Records[0].cf.request;
let finalrequest = JSON.stringify(request);
let headers = request.headers;
let useragent = JSON.stringify(headers["user-agent"][0].value);
let str = "";
if(/Android|webOS|iPhone|iPad|iPod|BlackBerry|IEMobile|Opera Mini|Mobile|mobile|CriOS/i.test(useragent)) {
str = content;
} else {
str = content1;
}
const response = {
status: '200',
statusDescription: 'OK',
body: str+useragent,
};
callback(null, response);
};
अब, लैम्ब्डा फ़ंक्शन को सहेजें। ध्यान दें कि हमें लैम्ब्डा फ़ंक्शन को प्रकाशित करने की आवश्यकता है ताकि इसे सभी क्षेत्रों के साथ उपयोग किया जा सके। प्रकाशित करने के लिए, हमें निम्नलिखित करने की आवश्यकता है -
कार्रवाई ड्रॉपडाउन से, का चयन करें Publish new version जैसा कि नीचे दिखाया गया है -
यदि आप, क्लिक करें Publish new version, यह निम्न स्क्रीन प्रदर्शित करता है -
अब, संस्करण विवरण दर्ज करें और क्लिक करें Publish। एआरएन नीचे दिखाए गए अनुसार एडब्ल्यूएस लैम्ब्डा फ़ंक्शन के संस्करण को प्रदर्शित करेगा -
नीचे दिखाए गए नए संस्करण में CloudFront ट्रिगर जोड़ें -
अब, CloudFront के लिए कॉन्फ़िगरेशन विवरण जोड़ें। CloudFront घटना के लिए विकल्प हैViewer request, Origin request, Origin response, तथा Viewer response।
अगला, पहले बनाए गए CloudFront वितरण को चुनें। सेevents, हम चयन करेंगे Viewer request। दर्शक के अनुरोध के आधार पर, उपयोगकर्ता-एजेंट से डेस्कटॉप / डिवाइस का निर्णय लिया जाएगा और प्रतिक्रिया को बदल दिया जाएगा। अगला, ट्रिगर विवरण जोड़ें।
एक बार ट्रिगर जुड़ जाने के बाद, हमें CloudFront से वितरण की प्रतीक्षा करने की आवश्यकता है।
एक बार स्टेटस बदल दिया जाए Deployed, हम CloudFront url का परीक्षण कर सकते हैं और ब्राउज़र में डोमेन नाम की जांच कर सकते हैं।
डेस्कटॉप ब्राउज़र में डिस्प्ले नीचे दिखाया गया है। यहां हमने उपयोगकर्ता-एजेंट को व्यूअर-रिक्वेस्ट इवेंट से प्रिंट किया है।
यह मोबाइल डिवाइस में डिस्प्ले है।
इस प्रकार, उपरोक्त उदाहरण में, हमने डेस्कटॉप और मोबाइल डिवाइस पर प्रतिक्रिया बदलने के लिए लैम्ब्डा @ एज का उपयोग किया है।