জেকিল, হুগো বা পেলিকানের মতো স্ট্যাটিক সাইট জেনারেটর দিয়ে তৈরি একটি স্ট্যাটিক ওয়েবসাইট হোস্ট করার বেশ কয়েকটি সস্তা উপায় রয়েছে: এই সম্পূর্ণ ব্লগটি জেকিল ব্যবহার করে স্থিরভাবে তৈরি করা হয়েছে। যাইহোক, আমি উপরের কোনো বিকল্প ব্যবহার করতে পারছি না, কারণ, এই ব্লগের জীবদ্দশায়, আমি ডোমেন নাম পরিবর্তন করেছি, URL স্কিম পরিবর্তন করেছি এবং পোস্টের নাম পরিবর্তন করেছি এবং আমি চাই সমস্ত পুরানো URL গুলিকে বাঁচিয়ে রাখুন আমি Apache ব্যবহার করে এই ব্লগটি হোস্ট করছি এবং, সম্প্রতি, একটি একক ভার্চুয়াল মেশিনে nginx, এবং সফ্টওয়্যারের যেকোন একটি অংশের পুনর্নির্দেশ বৈশিষ্ট্যগুলি ঠিক কাজ করে, কিন্তু আমি এটিকে নতুন এবং ভিন্ন কোথাও হোস্ট করতে প্রস্তুত ছিলাম একটি পূর্ববর্তী পোস্ট বর্ণনা করে যে কিভাবে আমি Google অ্যাপ ইঞ্জিন এবং পাইথন ব্যবহার করে একটি পুরানো ডোমেন থেকে একটি নতুন ডোমেনে URL পুনঃনির্দেশ করি, কিন্তু এখন আমার স্ট্যাটিক সামগ্রী পরিবেশন করার একটি উপায় প্রয়োজন **এবং** একই ডোমেন থেকে URL পুনঃনির্দেশ করুন। একই ডোমেন পুনঃনির্দেশের প্রয়োজনীয়তা কেন আমি কেবলমাত্র Google অ্যাপ ইঞ্জিনের স্ট্যাটিক কন্টেন্ট বৈশিষ্ট্যটি ব্যবহার করতে পারি না (উপরের তালিকায় লিঙ্ক করা আছে)। যাইহোক, স্ট্যাটিক কন্টেন্ট **এবং** একই ডোমেন রিডাইরেক্ট উভয় পরিবেশনের জন্য আমি একটি সাধারণ গোলং অ্যাপ্লিকেশনের সাথে একত্রে Google App Engine ব্যবহার করতে পারি ## কেন গুগল অ্যাপ ইঞ্জিন? আপনি পোস্টের বাকি অংশে ডুব দেওয়ার আগে, সম্ভবত আপনি ভাবছেন, কেন গুগল অ্যাপ ইঞ্জিনে একটি ব্লগ হোস্ট করবেন? এখানে আমার কারণ কেন: - যদি আপনার ট্র্যাফিক অ্যাপ ইঞ্জিনের 28 ইন্সট্যান্স ঘন্টার বিনামূল্যের স্তর এবং প্রতিদিন 1 GB প্রস্থান ট্র্যাফিকের মধ্যে ফিট করে, তাহলে ব্লগ হোস্ট করা কার্যত বিনামূল্যে - পুশিং আপডেটগুলি একটি কমান্ড দিয়ে সম্পন্ন করা হয় - স্ট্যাকড্রাইভার ব্যবহার করে লগিং এবং পর্যবেক্ষণ একত্রিত করা হয়েছে - ট্র্যাফিক প্যাটার্নের উপর ভিত্তি করে স্বয়ংক্রিয় আপ এবং ডাউন স্কেলিং - কয়েকটি ক্লিকের মাধ্যমে, ওয়েব লগগুলিকে সহজেই দীর্ঘমেয়াদী স্টোরেজ এবং অ্যাডহক বিশ্লেষণের জন্য BigQuery-এর মতো কিছুতে পুশ করা যেতে পারে - LetâÃÂÃÂs এনক্রিপ্ট ব্যবহার করে পরিচালিত SSL সার্টিফিকেট ## পূর্বশর্ত এই পোস্টটি নিম্নলিখিত অনুমান করে: - আপনি Google ক্লাউড প্ল্যাটফর্ম (GCP) এর সাথে পরিচিত এবং ইতিমধ্যে একটি GCP প্রকল্প তৈরি করেছেন৷ - আপনি Google Cloud SDK ইনস্টল করেছেন - আপনি প্রমাণীকরণ করেছেন আপনার Google অ্যাকাউন্টের বিরুদ্ধে gcloudcommand একটি GCP প্রকল্প তৈরি করুন আপনি যদি এখনও তৈরি না করে থাকেন তাহলে ক **জিসিপি প্রকল্প এই ধাপগুলি অনুসরণ করুন: - একটি ওয়েব ব্রাউজার খুলুন, এবং একটি Google অ্যাকাউন্ট তৈরি করুন বা লগ ইন করুন৷ - GCP কনসোলে নেভিগেট করুন - যদি এটি আপনার প্রথম GCP প্রকল্প হয়, তাহলে আপনাকে একটি GCP প্রকল্প তৈরি করতে বলা হবে। প্রতিটি Google অ্যাকাউন্ট 12 মাসের মধ্যে GCP-এ ব্যবহার করার জন্য $300 ক্রেডিট পায়। একটি GCP প্রকল্প তৈরি করতে আপনাকে একটি ক্রেডিট কার্ড প্রবেশ করতে হবে, তবে $300 ক্রেডিট খরচ না হওয়া পর্যন্ত বা 12 মাসের মেয়াদ শেষ না হওয়া পর্যন্ত এটি চার্জ করা হবে না - যদি এটি একটি নতুন GCP প্রজেক্ট হয়, তাহলে আপনাকে GCP কনসোলের কম্পিউট ইঞ্জিন বিভাগে নেভিগেট করে কম্পিউট ইঞ্জিন API সক্রিয় করতে হবে এবং আরম্ভ করার জন্য অপেক্ষা করতে হবে Google Cloud SDK ইনস্টল করুন আপনি যদি এখনও ইনস্টল না করে থাকেন **Google Cloud SDK এখানে নির্দেশাবলী অনুসরণ করুন gcloud প্রমাণীকরণ একবার আপনি একটি GCP প্রজেক্ট তৈরি করে Google Cloud SDK ইনস্টল করলে, শেষ ধাপ হল আপনার Google অ্যাকাউন্টে gcloud কমান্ড। আপনার টার্মিনাল অ্যাপ্লিকেশন খুলুন এবং নিম্নলিখিত কমান্ড চালান: gcloud auth লগইন আপনার ওয়েব ব্রাউজারে একটি ওয়েব পেজ খুলবে। আপনার Google অ্যাকাউন্ট নির্বাচন করুন এবং এটিকে GCP অ্যাক্সেস করার অনুমতি দিন। একবার সম্পন্ন হলে, আপনি প্রমাণীকৃত হবেন এবং এগিয়ে যেতে প্রস্তুত হবেন ## একটি ডিরেক্টরি তৈরি করুন এরপরে, আপনার ওয়ার্কস্টেশনে কোথাও একটি ডিরেক্টরি তৈরি করুন যাতে আপনার Google অ্যাপ ইঞ্জিন অ্যাপ্লিকেশনটি সংরক্ষণ করা যায়: mkdir ~/Sites/example.com/app_engine সেই ডিরেক্টরিতে পরিবর্তন করুন: cd ~/Sites/example.com/app_engine এই পোস্টের বাকি অংশ ধরে নিবে আপনি এই ডিরেক্টরির ভিতরে কাজ করছেন উপরন্তু, ভিতরে একটি ডিরেক্টরি তৈরি করুন **অ্যাপ_ইঞ্জিন** ডিরেক্টরিকে **স্ট্যাটিক বলা হয় mkdir ~/Sites/example.com/app_engine/static আপনি পরে এই ডিরেক্টরিটি পুনরায় দেখুন ## app.yaml তৈরি করুন গুগল অ্যাপ ইঞ্জিনের জন্য সাধারণত দুটি ফাইলের প্রয়োজন হয়: **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-এর মাধ্যমে ওয়েব অ্যাপ্লিকেশনে নেভিগেট করে, তাহলে তারা ডিফল্টরূপে 302 HTTPS সংস্করণে পুনঃনির্দেশিত হবে। এই কারণেই **redirect_http_response_code: 301** সেট করা হয়েছে। আমি সবসময় চাই যে ওয়েব অ্যাপ্লিকেশনটি HTTPS-এর মাধ্যমে পরিবেশিত হোক, এবং আমি চাই না সার্চ ইঞ্জিনগুলি HTTP থেকে HTTPS-এ পুনঃনির্দেশকে অস্থায়ী পুনঃনির্দেশ হিসাবে ব্যাখ্যা করুক; এটি একটি স্থায়ী পুনর্নির্দেশ আপনার যদি স্ট্যাটিক সম্পদ থাকে, এবং আপনি সম্ভবত তা করেন, তাহলে অ্যাপ ইঞ্জিনকে এটিকে অবহিত করা এবং আপনার অ্যাপ্লিকেশনের পরিবর্তে অবজেক্ট স্টোরেজ থেকে সেই সম্পদগুলিকে পরিবেশন করা সর্বোত্তম অনুশীলন। এটি করা সহজ এবং এর মাধ্যমেও করা হয় **app.yaml** ফাইল উদাহরণস্বরূপ, যদি আপনার কাছে একটি ফ্যাভিকন ফাইল, একটি CSS ডিরেক্টরি, একটি জাভাস্ক্রিপ্ট ডিরেক্টরি এবং একটি চিত্র ডিরেক্টরি থাকে, তাহলে নিম্নলিখিতগুলি ব্যবহার করুন **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 তৈরি করুন এর পরে, আপনার গোলং অ্যাপ্লিকেশন ফাইলের প্রয়োজন আপনার প্রয়োজন মেটাতে নিম্নলিখিত কোডের জন্য, ফাইল তৈরি করুন **main.go কপি করুন এবং নীচের কোডটি পেস্ট করুন এবং নিম্নলিখিত পরিবর্তনগুলি করুন: - মধ্যে ডোমেইন ভেরিয়েবল, সঠিক HTTP প্রোটোকলের সাথে আপনার ডোমেন নামের সাথে মেলাতে মান পরিবর্তন করুন - মধ্যে urlsmap, আপনার প্রয়োজনীয় পুনঃনির্দেশের সাথে মেলে সমস্ত মূল মান জোড়া প্রতিস্থাপন করুন। আপনি যে বর্তমান ডোমেইনের পুরানো ইউআরএলটি করতে চান তার পাথ অংশ (httpsexample.com/example-post-1.html-এর পরিবর্তে /example-post-1.html) দিয়ে প্রতিটি কী প্রতিস্থাপন করুন জিবন্ত রাখ. তারপর প্রতিটি মান বর্তমান ডোমেনের পাথ অংশের সাথে প্রতিস্থাপন করুন নতুন URL যেটিতে আপনি পুনঃনির্দেশ করতে চান সমস্ত পুনঃনির্দেশ হবে 301টি পুনঃনির্দেশ। এটি পরিবর্তন করে পরিবর্তন করা যেতে পারে **301** নিচের কোডে একটি ভিন্ন HTTP রিডাইরেক্ট স্ট্যাটাস কোড যেমন **302** প্যাকেজ প্রধান আমদানি ( "net/http""os""স্ট্রিংস") func init() { http.HandleFunc হ্যান্ডলার) } ফাঙ্ক হ্যান্ডলার (w http.ResponseWriter, r *http.Request) {// True (ok) যদি অনুরোধ urls ম্যাপে path মান থাকলে, ঠিক আছে := urls[r.URL.Path]; ঠিক আছে { মান = ডোমেন + মান http.Redirect(w, r, value, 301) } else { path := "static/"+ r.URL.Path // রিটার্ন 403 যদি HTTP অনুরোধটি এমন একটি ডিরেক্টরিতে হয় যা বিদ্যমান এবং করে একটি index.html ফাইল থাকবে না যদি f, err := os.Stat(path); err == শূন্য&& f.IsDir() { index := strings.TrimSuffix(path,+ "/index.html"যদি _, err := os. Open(index); err != nil { w.WriteHeader (403) w.Writebytehtml> 403 নিষিদ্ধ

403 Forbidden

return } } // Return custom 404 page if HTTP request is to a non-existent file if _, err := os.Stat(path); os.IsNotExist(err) { w.WriteHeader(404) http.ServeFile(w, r, "static/404.html") return // Withoutreturn, a "404 page not found" string will be displayed at the bottom of your custom 404 page } http.ServeFile(w, r, path) return } } var domain string = "httpsexample.com" var urls = map[string]string{ "/example-post-1.html": "/post/example-post-1.html", "/example-post-2.html": "/post/example-post-2.html", "/example-post-3.html": "/post/example-post-3.html", } ## Generate the Static Content With **app.yaml** and **main.go** saved, the last piece is to generate your static content and store it in the **static** directory you created earlier How you do this entirely depends on what static site generator you are using If you are using Jekyll, you can configure the **destination** parameter in Jekyll’s _ **config.yml** file to save your static content in any directory on your workstation. So, you could set the **destination** parameter to Sites/example.com/app_engine/static and, every time you run jekyll build, the static content will be saved in that directory ## Deploy to App Engine With **app.yaml **main.go and your static content generated, you are ready to deploy your Google App Engine application Assuming gcloud is already pointed at the Google Cloud Project you want to deploy to, verify with gcloud config list project, run the following command: gcloud app deploy The command will output the appspot URL your application will be deployed to and ask if you want to continue. Typically, the appspot URL is **httpsyour-project-id.appspot.com This is also a useful self-check to make sure you are not deploying your application to the wrong Google Cloud Project. If everything looks okay, type **Y** and **Enter** to deploy your application. Depending on how large your static content is, your application should be deployed within about one minute ## Setup DNS At this point, your application is deployed under URL **httpsyour-project-id.appspot.com Unless your website uses that as its domain name, you will probably want to setup a custom domain that uses your actual current domain name The App Engine section of the Google Cloud Console can be used to do this. Go here and follow the instructions to configure your custom domain Once that is complete and DNS has had time to propagate, you should be able to navigate in your web browser to one of your current domain’s old URLs, for example **httpsexample.com/example-post-1.html and have it redirect to your current domain’s new URLs, for example **httpsexample.com/post/example-post-1.html** ## Pushing Updates To push updates, make the necessary changes in your static site’s source directory, regenerate the static content, and redeploy to Google App Engine by changing into the Sites/example.com/app_engine** directory and running gcloud app deploy ## References - A Surprising Feature of Golang that Colored Me Impressed - How to check if a map contains a key in go? - Disable directory listing with http.FileServer - 3 Ways to Disable http.FileServer Directory Listings - Handling HTTP Request Errors in GO - HTTP and Error management in Go - please add ability to set custom 404 notFoundHandler for http.FileServer