আপনার ডাইনামিক কন্টেন্ট তৈরি ও পরিবেশন করতে অথবা মাইক্রোসার্ভিস হিসেবে REST API তৈরি করতে Cloud Run এর সাথে Firebase Hosting যুক্ত করুন।
Cloud Run ব্যবহার করে, আপনি একটি কন্টেইনার ইমেজে প্যাকেজ করা অ্যাপ্লিকেশন ডেপ্লয় করতে পারেন। তারপর, Firebase Hosting ব্যবহার করে, আপনি আপনার কন্টেইনারাইজড অ্যাপটি চালু করার জন্য HTTPS রিকোয়েস্ট পাঠাতে পারেন।
- Cloud Run বিভিন্ন ভাষা (গো, নোড.জেএস, পাইথন এবং জাভা সহ) সমর্থন করে, যা আপনাকে আপনার পছন্দের প্রোগ্রামিং ভাষা এবং ফ্রেমওয়ার্ক ব্যবহার করার সুবিধা দেয়।
- Cloud Run প্রাপ্ত অনুরোধগুলি সামাল দিতে আপনার কন্টেইনার ইমেজকে স্বয়ংক্রিয়ভাবে এবং পর্যায়ক্রমে স্কেল করে , এবং চাহিদা কমে গেলে স্কেল ডাউন করে।
- অনুরোধ প্রক্রিয়াকরণের সময় ব্যবহৃত সিপিইউ, মেমরি এবং নেটওয়ার্কিং খরচের জন্যই আপনাকে কেবল অর্থ প্রদান করতে হয় ।
Firebase Hosting সাথে সমন্বিত Cloud Run ব্যবহারিক ক্ষেত্র ও নমুনার জন্য, আমাদের সার্ভারলেস ওভারভিউ দেখুন।
এই নির্দেশিকাটি আপনাকে দেখাবে কীভাবে:
- একটি সহজ হ্যালো ওয়ার্ল্ড অ্যাপ্লিকেশন লিখুন
- একটি অ্যাপকে কন্টেইনারাইজ করুন এবং Artifact Registry তে আপলোড করুন।
- কন্টেইনার ইমেজটি Cloud Run ডিপ্লয় করুন
- আপনার কন্টেইনারাইজড অ্যাপে সরাসরি Hosting অনুরোধ
মনে রাখবেন যে, ডাইনামিক কন্টেন্ট পরিবেশনের পারফরম্যান্স উন্নত করতে আপনি ঐচ্ছিকভাবে আপনার ক্যাশ সেটিংস পরিবর্তন করতে পারেন।
শুরু করার আগে
Cloud Run ব্যবহার করার আগে, আপনাকে কিছু প্রাথমিক কাজ সম্পন্ন করতে হবে, যার মধ্যে রয়েছে একটি Cloud Billing অ্যাকাউন্ট তৈরি করা, Cloud Run API সক্রিয় করা এবং gcloud কমান্ড লাইন টুল ইনস্টল করা।
আপনার প্রকল্পের জন্য বিলিং সেট আপ করুন
Cloud Run বিনামূল্যে ব্যবহারের কোটা প্রদান করে, কিন্তু Cloud Run ব্যবহার বা পরখ করে দেখার জন্য আপনার ফায়ারবেস প্রজেক্টের সাথে যুক্ত একটি Cloud Billing অ্যাকাউন্ট অবশ্যই থাকতে হবে।
API সক্রিয় করুন এবং SDK ইনস্টল করুন।
Google APIs কনসোলে Cloud Run API সক্রিয় করুন:
Google APIs কনসোলে Cloud Run API পৃষ্ঠাটি খুলুন।
নির্দেশিত হলে আপনার ফায়ারবেস প্রজেক্টটি নির্বাচন করুন।
Cloud Run API পেজে Enable- এ ক্লিক করুন।
ক্লাউড এসডিকে ইনস্টল এবং চালু করুন ।
gcloudটুলটি সঠিক প্রজেক্টের জন্য কনফিগার করা আছে কিনা তা যাচাই করুন:gcloud config list
ধাপ ১ : নমুনা অ্যাপ্লিকেশনটি লিখুন
উল্লেখ্য যে, নিম্নলিখিত নমুনায় দেখানো ভাষাগুলো ছাড়াও Cloud Run আরও অনেক ভাষা সমর্থন করে।
যান
helloworld-goনামে একটি নতুন ডিরেক্টরি তৈরি করুন, তারপর সেটির ভেতরে যান:mkdir helloworld-go
cd helloworld-go
helloworld.goনামে একটি নতুন ফাইল তৈরি করুন, তারপর নিম্নলিখিত কোডটি যোগ করুন:এই কোডটি একটি সাধারণ ওয়েব সার্ভার তৈরি করে, যা
PORTএনভায়রনমেন্ট ভেরিয়েবল দ্বারা নির্ধারিত পোর্টে কাজ করে।
আপনার অ্যাপটি তৈরি হয়ে গেছে এবং এটি কন্টেইনারাইজ করে Artifact Registry তে আপলোড করার জন্য প্রস্তুত।
নোড.জেএস
helloworld-nodejsনামে একটি নতুন ডিরেক্টরি তৈরি করুন, তারপর সেটির ভেতরে যান:mkdir helloworld-nodejs
cd helloworld-nodejs
নিম্নলিখিত বিষয়বস্তু সহ একটি
package.jsonফাইল তৈরি করুন:index.jsনামে একটি নতুন ফাইল তৈরি করুন, তারপর নিম্নলিখিত কোডটি যোগ করুন:এই কোডটি একটি সাধারণ ওয়েব সার্ভার তৈরি করে, যা
PORTএনভায়রনমেন্ট ভেরিয়েবল দ্বারা নির্ধারিত পোর্টে কাজ করে।
আপনার অ্যাপটি তৈরি হয়ে গেছে এবং এটি কন্টেইনারাইজ করে Artifact Registry তে আপলোড করার জন্য প্রস্তুত।
পাইথন
helloworld-pythonনামে একটি নতুন ডিরেক্টরি তৈরি করুন, তারপর সেটির ভেতরে যান:mkdir helloworld-python
cd helloworld-python
app.pyনামে একটি নতুন ফাইল তৈরি করুন, তারপর নিম্নলিখিত কোডটি যোগ করুন:এই কোডটি একটি সাধারণ ওয়েব সার্ভার তৈরি করে, যা
PORTএনভায়রনমেন্ট ভেরিয়েবল দ্বারা নির্ধারিত পোর্টে কাজ করে।
আপনার অ্যাপটি তৈরি হয়ে গেছে এবং এটি কন্টেইনারাইজ করে Artifact Registry তে আপলোড করার জন্য প্রস্তুত।
জাভা
Java SE 8 বা তার পরবর্তী সংস্করণের JDK এবং CURL ইনস্টল করুন।
মনে রাখবেন, পরবর্তী ধাপে নতুন ওয়েব প্রজেক্টটি তৈরি করার জন্য আমাদের শুধু এই কাজটি করতে হবে। পরে বর্ণিত Dockerfile-টি কন্টেইনারের মধ্যে সমস্ত ডিপেন্ডেন্সি লোড করে দেবে।
কনসোল থেকে, cURL ব্যবহার করে একটি নতুন খালি ওয়েব প্রজেক্ট তৈরি করুন এবং তারপর আনজিপ কমান্ডগুলো চালান:
curl https://start.spring.io/starter.zip \ -d dependencies=web \ -d name=helloworld \ -d artifactId=helloworld \ -o helloworld.zipunzip helloworld.zip
এটি একটি SpringBoot প্রজেক্ট তৈরি করে।
src/main/java/com/example/helloworld/HelloworldApplication.javaতে থাকাSpringBootApplicationক্লাসটি আপডেট করুন। এর জন্য/ম্যাপিং পরিচালনা করতে একটি@RestControllerযোগ করুন এবংTARGETএনভায়রনমেন্ট ভেরিয়েবল সরবরাহ করার জন্য একটি@Valueফিল্ডও যোগ করুন।এই কোডটি একটি সাধারণ ওয়েব সার্ভার তৈরি করে, যা
PORTএনভায়রনমেন্ট ভেরিয়েবল দ্বারা নির্ধারিত পোর্টে কাজ করে।
আপনার অ্যাপটি তৈরি হয়ে গেছে এবং এটি কন্টেইনারাইজ করে Artifact Registry তে আপলোড করার জন্য প্রস্তুত।
ধাপ ২ : একটি অ্যাপকে কন্টেইনারাইজ করুন এবং Artifact Registry তে আপলোড করুন।
সোর্স ফাইলগুলোর ডিরেক্টরিতেই
Dockerfileনামে একটি নতুন ফাইল তৈরি করে স্যাম্পল অ্যাপটিকে কন্টেইনারাইজ করুন। নিচের কন্টেন্টটি আপনার ফাইলে কপি করুন।যান
নোড.জেএস
পাইথন
জাভা
আপনার Dockerfile থাকা ডিরেক্টরি থেকে নিম্নলিখিত কমান্ডটি চালিয়ে Cloud Build ব্যবহার করে আপনার কন্টেইনার ইমেজ তৈরি করুন:
gcloud builds submit --tag gcr.io/PROJECT_ID/helloworld
সফল হলে, আপনি ছবির নাম সম্বলিত একটি SUCCESS বার্তা দেখতে পাবেন।
(gcr.io/ PROJECT_ID /helloworld)
কন্টেইনার ইমেজটি এখন Artifact Registry তে সংরক্ষিত আছে এবং চাইলে এটি পুনরায় ব্যবহার করা যেতে পারে।
উল্লেখ্য যে, Cloud Build পরিবর্তে, আপনি আপনার কন্টেইনারটি স্থানীয়ভাবে তৈরি করতে ডকারের স্থানীয়ভাবে ইনস্টল করা সংস্করণ ব্যবহার করতে পারেন।
ধাপ ৩ : কন্টেইনার ইমেজটি Cloud Run ডেপ্লয় করুন
সর্বোত্তম পারফরম্যান্সের জন্য, নিম্নলিখিত অঞ্চলগুলি ব্যবহার করে আপনার Cloud Run পরিষেবাটিকে Hosting সাথে সহ-অবস্থান করান:
-
us-west1 -
us-central1 -
us-east1 -
europe-west1 -
asia-east1
Hosting থেকে Cloud Run রিরাইট নিম্নলিখিত অঞ্চলগুলিতে সমর্থিত:
-
asia-east1 -
asia-east2 -
asia-northeast1 -
asia-northeast2 -
asia-northeast3 -
asia-south1 -
asia-south2 -
asia-southeast1 -
asia-southeast2 -
australia-southeast1 -
australia-southeast2 -
europe-central2 -
europe-north1 -
europe-southwest1 -
europe-west1 -
europe-west12 -
europe-west2 -
europe-west3 -
europe-west4 -
europe-west6 -
europe-west8 -
europe-west9 -
me-central1 -
me-west1 -
northamerica-northeast1 -
northamerica-northeast2 -
southamerica-east1 -
southamerica-west1 -
us-central1 -
us-east1 -
us-east4 -
us-east5 -
us-south1 -
us-west1 -
us-west2 -
us-west3 -
us-west4 -
us-west1 -
us-central1 -
us-east1 -
europe-west1 -
asia-east1
নিম্নলিখিত কমান্ড ব্যবহার করে স্থাপন করুন:
gcloud run deploy --image gcr.io/PROJECT_ID/helloworld
জিজ্ঞাসা করা হলে:
- একটি অঞ্চল নির্বাচন করুন (উদাহরণস্বরূপ
us-central1) - সার্ভিসের নামটি নিশ্চিত করুন (উদাহরণস্বরূপ,
helloworld)। - প্রমাণীকরণবিহীন আহ্বানের অনুমতি দিতে
Yদিন।
- একটি অঞ্চল নির্বাচন করুন (উদাহরণস্বরূপ
ডিপ্লয়মেন্ট সম্পূর্ণ হওয়ার জন্য কিছুক্ষণ অপেক্ষা করুন। সফল হলে, কমান্ড লাইনে সার্ভিস ইউআরএলটি প্রদর্শিত হবে। উদাহরণস্বরূপ
https://helloworld- RANDOM_HASH -us-central1.a.run.appওয়েব ব্রাউজারে সার্ভিস ইউআরএলটি খুলে আপনার ডেপ্লয় করা কন্টেইনারটি ভিজিট করুন।
পরবর্তী ধাপে দেখানো হবে কীভাবে একটি Firebase Hosting URL থেকে এই কন্টেইনারাইজড অ্যাপটি অ্যাক্সেস করতে হয়, যাতে এটি আপনার Firebase-হোস্টেড সাইটের জন্য ডাইনামিক কন্টেন্ট তৈরি করতে পারে।
ধাপ ৪: আপনার কন্টেইনারাইজড অ্যাপে হোস্টিং অনুরোধগুলি সরাসরি পাঠান
রিরাইট রুল ব্যবহার করে, আপনি নির্দিষ্ট প্যাটার্নের সাথে মিলে যাওয়া রিকোয়েস্টগুলোকে একটিমাত্র গন্তব্যে পাঠাতে পারেন।
নিম্নলিখিত উদাহরণটি দেখায় কিভাবে আপনার Hosting সাইটের /helloworld পৃষ্ঠা থেকে আসা সমস্ত অনুরোধকে আপনার helloworld কন্টেইনার ইনস্ট্যান্সের সূচনা এবং চালনায় নির্দেশিত করা যায়।
নিশ্চিত করুন যে:
আপনার কাছে Firebase CLI-এর সর্বশেষ সংস্করণটি রয়েছে।
আপনি Firebase Hosting চালু করেছেন।
CLI ইনস্টল করা এবং Hosting চালু করার বিষয়ে বিস্তারিত নির্দেশাবলীর জন্য, Hosting এর 'গেট স্টার্টেড' গাইডটি দেখুন।
আপনার
firebase.jsonফাইলটি খুলুন।hostingসেকশনের অধীনে নিম্নলিখিতrewriteকনফিগারেশনটি যোগ করুন:"hosting": { // ... // Add the "rewrites" attribute within "hosting" "rewrites": [ { "source": "/helloworld", "run": { "serviceId": "helloworld", // "service name" (from when you deployed the container image) "region": "us-central1", // optional (if omitted, default is us-central1) "pinTag": true // optional (see note below) } } ] }
আপনার প্রজেক্ট ডিরেক্টরির রুট থেকে নিম্নলিখিত কমান্ডটি চালিয়ে আপনার সাইটে হোস্টিং কনফিগারেশনটি স্থাপন করুন:
firebase deploy --only hosting
এই ফিচারের মাধ্যমে, আপনি নিশ্চিত করতে পারেন যে আপনার সাইটের ডাইনামিক কন্টেন্ট তৈরির জন্য ব্যবহৃত Cloud Run সার্ভিসের রিভিশনটি আপনার স্ট্যাটিক Hosting রিসোর্স এবং Hosting কনফিগের সাথে সিঙ্ক করা থাকে। এছাড়াও, এই ফিচারটি আপনাকে Hosting প্রিভিউ চ্যানেলে Cloud Run আপনার রিরাইটগুলো প্রিভিউ করার সুযোগ দেয়।
আপনি যদি
hosting.rewritesকনফিগের কোনোrunব্লকে"pinTag": trueযোগ করেন, তাহলে আপনার স্ট্যাটিক Hosting রিসোর্স এবং কনফিগারেশন ডিপ্লয়ের সময় Cloud Run সার্ভিসের সর্বশেষ সংস্করণে পিন করা থাকবে। আপনি যদি আপনার সাইটের কোনো সংস্করণ রোল ব্যাক করেন, তাহলে "পিন করা" Cloud Run সার্ভিসের সংস্করণটিও রোল ব্যাক হয়ে যাবে।এই ফিচারটি Cloud Run ট্যাগ-এর উপর নির্ভর করে, যেখানে প্রতি সার্ভিসে ১০০০টি এবং প্রতি অঞ্চলে ২০০০টি ট্যাগের সীমা রয়েছে। এর মানে হলো, শত শতবার ডেপ্লয় করার পর একটি সাইটের সবচেয়ে পুরোনো সংস্করণগুলো কাজ করা বন্ধ করে দিতে পারে।
আপনার কন্টেইনারটি এখন নিম্নলিখিত URL-গুলির মাধ্যমে অ্যাক্সেস করা যাবে:
আপনার ফায়ারবেস সাবডোমেনগুলি:
PROJECT_ID .web.app/এবংPROJECT_ID .firebaseapp.com/যেকোনো সংযুক্ত কাস্টম ডোমেইন :
CUSTOM_DOMAIN /
রিরাইট রুল সম্পর্কে আরও বিস্তারিত জানতে Hosting কনফিগারেশন পেজটি দেখুন। এছাড়াও, আপনি বিভিন্ন Hosting কনফিগারেশনের জন্য রেসপন্সগুলোর অগ্রাধিকার ক্রম সম্পর্কে জানতে পারবেন।
স্থানীয়ভাবে পরীক্ষা করুন
ডেভেলপমেন্ট চলাকালীন, আপনি আপনার কন্টেইনার ইমেজটি স্থানীয়ভাবে রান ও টেস্ট করতে পারেন। বিস্তারিত নির্দেশাবলীর জন্য, Cloud Run ডকুমেন্টেশন দেখুন।
পরবর্তী পদক্ষেপ
একটি গ্লোবাল সিডিএন-এ আপনার ডাইনামিক কন্টেন্টের ক্যাশিং সেট আপ করুন ।
Firebase অ্যাডমিন SDK ব্যবহার করে অন্যান্য Firebase পরিষেবাগুলির সাথে যোগাযোগ করুন।
Cloud Run সম্পর্কে আরও জানুন, যার মধ্যে কন্টেইনার সেট আপ, পরিচালনা এবং কনফিগার করার জন্য বিস্তারিত নির্দেশিকা রয়েছে।
Cloud Run এর মূল্য এবং কোটা ও সীমাগুলো পর্যালোচনা করুন।