Jekyll, Hugo, या Pelican जैसे स्थैतिक साइट जनरेटर से उत्पन्न स्थैतिक वेबसाइट को होस्ट करने के कई सस्ते तरीके हैं: यह पूरा ब्लॉग जेकील का उपयोग करके वैधानिक रूप से उत्पन्न किया गया है। हालांकि, मैं उपरोक्त किसी भी विकल्प का उपयोग करने में असमर्थ हूं, क्योंकि इस ब्लॉग के जीवनकाल में, मैंने डोमेन नाम बदल दिए हैं, यूआरएल योजनाओं को बदल दिया है, और पदों का नाम बदल दिया है, और मैं चाहता हूं सभी पुराने URL को जीवित रखें मैं अपाचे और हाल ही में, एकल वर्चुअल मशीन पर nginx का उपयोग करके इस ब्लॉग की मेजबानी कर रहा हूं, और सॉफ्टवेयर के किसी भी टुकड़े की पुनर्निर्देशन विशेषताएं ठीक काम करती हैं, लेकिन मैं इसे कहीं नए और अलग तरीके से होस्ट करने के लिए तैयार था एक पिछली पोस्ट बताती है कि कैसे मैं Google ऐप इंजन और पायथन का उपयोग करके एक पुराने डोमेन से नए डोमेन पर URL को रीडायरेक्ट करता हूं, लेकिन अब मुझे स्टैटिक कंटेंट परोसने का एक तरीका चाहिए **और** एक ही डोमेन से यूआरएल रीडायरेक्ट करते हैं। उसी डोमेन रीडायरेक्शन आवश्यकता के कारण मैं केवल Google App EngineâÃÂàकी स्थिर सामग्री केवल सुविधा (उपरोक्त सूची में लिंक) का उपयोग नहीं कर सकता। हालांकि, मैं स्थिर सामग्री ** और ** समान डोमेन रीडायरेक्ट दोनों की सेवा के लिए एक साधारण गोलंग एप्लिकेशन के संयोजन में Google ऐप इंजन का उपयोग कर सकता हूं ## Google ऐप इंजन क्यों? इससे पहले कि आप शेष पोस्ट में गोता लगाएँ, शायद आप सोच रहे होंगे कि Google App Engine पर एक ब्लॉग क्यों होस्ट करें? यहाँ मेरे कारण हैं: - यदि आपका ट्रैफ़िक ऐप इंजन के 28 इंस्टेंस घंटों के फ्री टियर और प्रति दिन 1 जीबी इग्रेस ट्रैफ़िक के भीतर फिट बैठता है, तो ब्लॉग को होस्ट करना व्यावहारिक रूप से मुफ़्त है - पुशिंग अपडेट एक कमांड के साथ किया जाता है - स्टैकड्राइवर का उपयोग करके लॉगिंग और मॉनिटरिंग को एकीकृत किया गया है - ट्रैफ़िक पैटर्न के आधार पर स्वचालित अप और डाउन स्केलिंग - कुछ क्लिक के साथ, वेब लॉग को आसानी से लंबी अवधि के भंडारण और तदर्थ विश्लेषण के लिए BigQuery जैसी किसी चीज़ पर धकेला जा सकता है - LetâÃÂÃÂs Encrypt का उपयोग करके प्रबंधित SSL प्रमाणपत्र ## पूर्वापेक्षाएँ यह पद निम्नलिखित मानता है: - आप Google क्लाउड प्लेटफ़ॉर्म (GCP) से परिचित हैं और पहले ही एक GCP प्रोजेक्ट बना चुके हैं - आपने Google क्लाउड एसडीके स्थापित किया है - आपने प्रमाणित किया है आपके Google खाते के विरुद्ध gcloudcommand एक जीसीपी परियोजना बनाएँ अगर आपने अभी तक नहीं बनाया है **जीसीपी परियोजना इन चरणों का पालन करें: - एक वेब ब्राउज़र खोलें, और एक Google खाता बनाएँ या उसमें लॉग इन करें - GCP कंसोल पर नेविगेट करें - अगर यह आपका पहला जीसीपी प्रोजेक्ट है, तो आपको एक जीसीपी प्रोजेक्ट बनाने के लिए कहा जाएगा। GCP की ओर 12 महीनों के भीतर उपयोग करने के लिए प्रत्येक Google खाते को $300 का क्रेडिट मिलता है। GCP प्रोजेक्ट बनाने के लिए आपको एक क्रेडिट कार्ड दर्ज करना होगा, लेकिन $300 क्रेडिट का उपभोग करने या 12 महीने समाप्त होने तक इसका शुल्क नहीं लिया जाएगा - यदि यह एक नया जीसीपी प्रोजेक्ट है, तो आपको जीसीपी कंसोल के कंप्यूट इंजन सेक्शन में नेविगेट करके कंप्यूट इंजन एपीआई को सक्षम करना होगा और आरंभीकरण के पूरा होने की प्रतीक्षा करनी होगी। Google क्लाउड एसडीके स्थापित करें यदि आपने अभी तक इंस्टॉल नहीं किया है **Google क्लाउड एसडीके यहां दिए गए निर्देशों का पालन करता है जीक्लाउड प्रमाणित करें एक बार जब आप GCP प्रोजेक्ट बना लेते हैं और Google क्लाउड SDK स्थापित कर लेते हैं, तो अंतिम चरण प्रमाणित करना होता है आपके Google खाते के लिए gcloud कमांड। अपना टर्मिनल एप्लिकेशन खोलें और निम्न कमांड चलाएँ: gcloud प्रमाणीकरण लॉगिन आपके वेब ब्राउजर में एक वेब पेज खुलेगा। अपना Google खाता चुनें और उसे GCP तक पहुँचने की अनुमति दें। एक बार पूरा हो जाने पर, आप प्रमाणित हो जाएंगे और आगे बढ़ने के लिए तैयार होंगे ## एक निर्देशिका बनाएँ इसके बाद, अपने Google ऐप इंजन एप्लिकेशन को स्टोर करने के लिए अपने वर्कस्टेशन पर कहीं एक निर्देशिका बनाएं: एमकेडीआईआर ~/साइट्स/example.com/app_engine उस निर्देशिका में बदलें: सीडी ~/साइट्स/example.com/app_engine इस पोस्ट के शेष भाग में यह माना जाएगा कि आप इस निर्देशिका के अंदर काम कर रहे हैं इसके अतिरिक्त, के अंदर एक निर्देशिका बनाएँ **app_engine** निर्देशिका जिसे **स्थैतिक कहा जाता है mkdir ~/Sites/example.com/app_engine/static आप बाद में इस निर्देशिका पर फिर से जाएँगे ## ऐप.यामल बनाएं Google ऐप इंजन को आम तौर पर दो फाइलों की आवश्यकता होती है: **app.yaml** और एक **एप्लिकेशन फ़ाइल** जिसे Python, Golang, Java, या PHP में लिखा गया है - इस मामले में यह गोलंग होने जा रहा है। **app.yaml** आपके एप्लिकेशन को चलाने के लिए आवश्यक कॉन्फ़िगरेशन प्रदान करता है। **app.yaml में बहुत सारे अलग-अलग पैरामीटर मौजूद हो सकते हैं, वे पैरामीटर उपयोग की गई प्रोग्रामिंग भाषा के आधार पर भिन्न हो सकते हैं। इस पोस्ट के लिए, गोलंग का उपयोग किया जाएगा, और आप गोलंग के सभी उपलब्ध पैरामीटर यहां पा सकते हैं फ़ाइल बनाएँ **app.yaml** निम्नलिखित सामग्री के साथ: रनटाइम: go api_version: go1 हैंडलर: - url:script: _go_app सुरक्षित: हमेशा रीडायरेक्ट_http_response_code: 301 नोटिस जो **सुरक्षित: हमेशा** सेट किया गया है। इसका मतलब है कि गोलंग एप्लिकेशन को हमेशा HTTPS पर सर्व किया जाएगा। यदि कोई अंतिम उपयोगकर्ता HTTP पर वेब एप्लिकेशन पर नेविगेट करता है, तो वह डिफ़ॉल्ट रूप से HTTPS संस्करण पर 302 पुनर्निर्देशित हो जाएगा। इसलिए **redirect_http_response_code: 301** भी सेट किया गया है। मैं हमेशा चाहता हूं कि वेब एप्लिकेशन को एचटीटीपीएस पर परोसा जाए, और मैं नहीं चाहता कि खोज इंजन एचटीटीपी से एचटीटीपीएस पर पुनर्निर्देशन को अस्थायी रीडायरेक्ट के रूप में समझें; यह एक स्थायी रीडायरेक्ट है यदि आपके पास स्थिर संपत्तियां हैं, और आप शायद करते हैं, तो इसके बारे में ऐप इंजन को सूचित करना सबसे अच्छा अभ्यास है और इसे अपने एप्लिकेशन के बजाय ऑब्जेक्ट स्टोरेज से उन संपत्तियों की सेवा करने दें। इसे करना आसान भी है और इसके द्वारा भी किया जाता है **app.yaml** फ़ाइल उदाहरण के लिए, यदि आपके पास एक फ़ेविकॉन फ़ाइल, एक CSS निर्देशिका, एक Javascript निर्देशिका और एक छवि निर्देशिका है, तो निम्न का उपयोग करें **app.yaml** फ़ाइल: रनटाइम: go api_version: go1 हैंडलर: - url: /favicon.png$ static_files: static/favicon.png अपलोड करें: static/favicon.png - url: /css static_dir: static/css - url: /js static_dir: static/js - url: /images static_dir: static/images - url:script: _go_app सुरक्षित: हमेशा रीडायरेक्ट_http_response_code: 301 ## मेन.गो बनाएं अगला, आपको गोलंग एप्लिकेशन फ़ाइल की आवश्यकता है अपनी आवश्यकताओं को पूरा करने के लिए निम्न कोड के लिए, फ़ाइल बनाएँ **main.go नीचे दिए गए कोड को कॉपी और पेस्ट करें, और निम्नलिखित संशोधन करें: - में डोमेनवैरिएबल, सही HTTP प्रोटोकॉल के साथ अपने डोमेन नाम से मिलान करने के लिए मान बदलें - में urlsmap, आपके लिए आवश्यक रीडायरेक्ट से मिलान करने के लिए सभी कुंजी मान युग्मों को प्रतिस्थापित करें। प्रत्येक कुंजी को वर्तमान डोमेन के पुराने URL के केवल पथ भाग ( /example-post-1.htmlबजाय httpsexample.com/example-post-1.html) से बदलें। जिंदा रहो। फिर प्रत्येक मान को वर्तमान डोमेन के पथ भाग के साथ बदलें एक नया यूआरएल जिसे आप रीडायरेक्ट करना चाहते हैं सभी रीडायरेक्ट 301 रीडायरेक्ट होंगे। इसे बदलकर संशोधित किया जा सकता है **301** नीचे दिए गए कोड में एक अलग HTTP रीडायरेक्ट स्थिति कोड जैसे **302** पैकेज मुख्य आयात ("नेट/http""os""स्ट्रिंग्स") func init() { http.HandleFunc हैंडलर) } func हैंडलर (w http.ResponseWriter, r *http.Request) { // True (ठीक) अगर अनुरोध पथ urls मानचित्र में है यदि मान, ठीक है:= urls[r.URL.Path]; ok { value = domain + value http.Redirect(w, r, value, 301) } else { path := "static/"+ r.URL.Path // रिटर्न 403 अगर HTTP रिक्वेस्ट ऐसी डायरेक्टरी के लिए है जो मौजूद है और करती है यदि f, err := os.Stat(path); err == nil&& f.IsDir() { index :=strings.TrimSuffix(path,+ "/index.html"if _, err := os.Open(index); err != nil { w.WriteHeader (403) w.Writebytehtml>