Check out what’s new from Firebase at Google I/O 2022. Learn more

একাধিক সাইট জুড়ে প্রকল্প সম্পদ শেয়ার করুন

আপনি একটি ফায়ারবেস প্রকল্পে এক বা একাধিক Firebase হোস্টিং সাইট সেট আপ করতে পারেন। যেহেতু সাইটগুলো সব একই ফায়ারবেস প্রোজেক্টে রয়েছে, তাই সব সাইট প্রজেক্টের অন্যান্য ফায়ারবেস রিসোর্স অ্যাক্সেস করতে পারে।

একই ফায়ারবেস প্রকল্পের মধ্যে একাধিক হোস্টিং সাইট সেট আপ করার মাধ্যমে, আপনি আরও সহজে সম্পর্কিত সাইট এবং অ্যাপগুলির মধ্যে Firebase সংস্থানগুলি ভাগ করতে পারেন৷ উদাহরণস্বরূপ, আপনি যদি একই Firebase প্রকল্পে আপনার ব্লগ, অ্যাডমিন প্যানেল এবং সর্বজনীন অ্যাপকে পৃথক সাইট হিসাবে সেট আপ করেন, তবে তারা সবাই একই Firebase প্রমাণীকরণ ব্যবহারকারী ডাটাবেস শেয়ার করতে পারে, পাশাপাশি তাদের নিজস্ব অনন্য ডোমেন বা সামগ্রীও থাকে।

ধাপ 1 : আপনার Firebase CLI সংস্করণ আপডেট করুন

Firebase CLI-এর সর্বশেষ সংস্করণে আপডেট করে সবচেয়ে বর্তমান Firebase হোস্টিং বৈশিষ্ট্যগুলি অ্যাক্সেস করুন৷

ধাপ 2 : অতিরিক্ত সাইট যোগ করুন

নিম্নলিখিত পদ্ধতিগুলির মধ্যে একটি ব্যবহার করে একটি Firebase প্রকল্পে অতিরিক্ত সাইট যোগ করুন:

  • Firebase কনসোলের হোস্টিং পৃষ্ঠায় ওয়ার্কফ্লো ব্যবহার করুন

  • Firebase CLI কমান্ডটি ব্যবহার করুন: firebase hosting:sites:create SITE_ID

  • হোস্টিং REST API ব্যবহার করুন: projects.sites.create

এই প্রতিটি পদ্ধতির জন্য, আপনি একটি SITE_ID নির্দিষ্ট করবেন যা সাইটের জন্য Firebase-প্রোভিশন করা ডিফল্ট সাবডোমেন তৈরি করতে ব্যবহৃত হয়:

  • SITE_ID .web.app
  • SITE_ID .firebaseapp.com

যেহেতু এই URLগুলির জন্য SITE_ID ব্যবহার করা হয়, তাই সাইট আইডির নিম্নলিখিত প্রয়োজনীয়তা রয়েছে:

  • একটি বৈধ হোস্টনাম লেবেল হতে হবে, যার অর্থ এটি ধারণ করতে পারে না . , _ , ইত্যাদি
  • 30 অক্ষর বা তার কম হতে হবে
  • Firebase এর মধ্যে বিশ্বব্যাপী অনন্য হতে হবে

প্রতিটি সাইটে, একই বিষয়বস্তু এবং একাধিক ইউআরএলে কনফিগারেশন পরিবেশনের জন্য আপনি ঐচ্ছিকভাবে কাস্টম ডোমেন যোগ করতে পারেন।

একটি মাধ্যমিক সাইট মুছুন

নিম্নলিখিত পদ্ধতিগুলির মধ্যে একটি ব্যবহার করে ফায়ারবেস প্রকল্প থেকে অবাঞ্ছিত সাইটগুলি মুছুন:

  • Firebase কনসোলের হোস্টিং পৃষ্ঠায় ওয়ার্কফ্লো ব্যবহার করুন

  • Firebase CLI কমান্ডটি ব্যবহার করুন: firebase hosting:sites:delete SITE_ID

  • হোস্টিং REST API ব্যবহার করুন: projects.sites.delete

মনে রাখবেন যে আপনি ডিফল্ট সাইটটি মুছে ফেলতে পারবেন না, যেটির SITE_ID আপনার ফায়ারবেস প্রোজেক্ট আইডির মতই আছে।

ধাপ 3 : আপনার সাইটের জন্য স্থাপনার লক্ষ্য সেট আপ করুন

যখন আপনার একাধিক সাইট থাকে এবং আপনি Firebase CLI ডিপ্লোয় কমান্ড চালান, তখন CLI-এর যোগাযোগের একটি উপায় প্রয়োজন প্রতিটি সাইটে কোন সেটিংস স্থাপন করা উচিত। লক্ষ্য স্থাপনের মাধ্যমে আপনি আপনার firebase.json কনফিগারেশন ফাইলে এবং আপনার সাইটে পরীক্ষা বা স্থাপনের জন্য আপনার Firebase CLI কমান্ডে TARGET_NAME সহ একটি নির্দিষ্ট সাইটকে অনন্যভাবে সনাক্ত করতে পারেন।

একটি স্থাপনার লক্ষ্য তৈরি করতে এবং একটি হোস্টিং সাইটে একটি TARGET_NAME প্রয়োগ করতে, আপনার প্রকল্প ডিরেক্টরির রুট থেকে নিম্নলিখিত CLI কমান্ডটি চালান:

firebase target:apply hosting TARGET_NAME RESOURCE_IDENTIFIER

যেখানে পরামিতিগুলি রয়েছে:

  • TARGET_NAME — আপনি যে হোস্টিং সাইটে স্থাপন করছেন তার জন্য একটি অনন্য নাম (যেটি আপনি নিজেই সংজ্ঞায়িত করেছেন)

  • RESOURCE_IDENTIFIER — হোস্টিং সাইটের জন্য SITE_ID আপনার ফায়ারবেস প্রকল্পে তালিকাভুক্ত

উদাহরণস্বরূপ, আপনি যদি আপনার Firebase প্রকল্পে দুটি সাইট ( myapp-blog এবং myapp-app ) তৈরি করে থাকেন, তাহলে আপনি নিম্নলিখিত কমান্ডগুলি চালিয়ে প্রতিটি সাইটে একটি অনন্য TARGET_NAME (যথাক্রমে blog এবং app ) প্রয়োগ করতে পারেন:

firebase target:apply hosting blog myapp-blog
firebase target:apply hosting app myapp-app

লক্ষ্য স্থাপনের জন্য সেটিংস আপনার প্রকল্প ডিরেক্টরির .firebaserc ফাইলে সংরক্ষণ করা হয়, তাই আপনাকে প্রতি প্রকল্পের জন্য শুধুমাত্র একবার লক্ষ্য স্থাপন করতে হবে।

ধাপ 4 : প্রতিটি সাইটের জন্য হোস্টিং কনফিগারেশন নির্ধারণ করুন

আপনি আপনার firebase.json ফাইলে এটির হোস্টিং কনফিগারেশন সংজ্ঞায়িত করার সময় একটি সাইটের প্রয়োগকৃত TARGET_NAME ব্যবহার করুন৷

  • যদি আপনার firebase.json ফাইল একাধিক সাইটের জন্য কনফিগারেশন সংজ্ঞায়িত করে, একটি অ্যারে বিন্যাস ব্যবহার করুন:

    {
      "hosting": [ {
          "target": "blog",  // "blog" is the applied TARGET_NAME for the Hosting site "myapp-blog"
          "public": "blog/dist",  // contents of this folder are deployed to the site "myapp-blog"
    
          // ...
        },
        {
          "target": "app",  // "app" is the applied TARGET_NAME for the Hosting site "myapp-app"
          "public": "app/dist",  // contents of this folder are deployed to the site "myapp-app"
    
          // ...
    
          "rewrites": [...]  // You can define specific Hosting configurations for each site
        }
      ]
    }
    
  • যদি আপনার firebase.json ফাইল শুধুমাত্র একটি সাইটের জন্য কনফিগারেশন সংজ্ঞায়িত করে, তাহলে একটি অ্যারে বিন্যাস ব্যবহার করার প্রয়োজন নেই:

    {
      "hosting": {
          "target": "blog",
          "public": "dist",
    
          // ...
    
          "rewrites": [...]
      }
    }
    

ধাপ 5 : স্থানীয়ভাবে পরীক্ষা করুন, পরিবর্তনের পূর্বরূপ দেখুন এবং আপনার সাইটে স্থাপন করুন

আপনার স্থানীয় প্রজেক্ট ডিরেক্টরির রুট থেকে নিচের যেকোনো কমান্ড চালান।

আদেশ বর্ণনা
firebase emulators:start --only hosting স্থানীয়ভাবে হোস্ট করা URL এ হোস্টিং বিষয়বস্তু এবং ডিফল্ট হোস্টিং সাইটের কনফিগারেশন অনুকরণ করে
firebase emulators:start --only hosting: TARGET_NAME স্থানীয়ভাবে হোস্ট করা URL এ হোস্টিং বিষয়বস্তু এবং নির্দিষ্ট হোস্টিং সাইটের কনফিগারেশন অনুকরণ করে
firebase hosting:channel:deploy \
CHANNEL_ID
একটি পূর্বরূপ URL-এ হোস্টিং সামগ্রী এবং ডিফল্ট হোস্টিং সাইটের কনফিগারেশন স্থাপন করে
firebase hosting:channel:deploy \
CHANNEL_ID --only TARGET_NAME
একটি পূর্বরূপ URL-এ নির্দিষ্ট হোস্টিং সাইটের হোস্টিং বিষয়বস্তু এবং কনফিগারেশন স্থাপন করে
firebase deploy --only hosting firebase.json এ কনফিগার করা সমস্ত হোস্টিং সাইটের লাইভ চ্যানেলে হোস্টিং বিষয়বস্তু এবং কনফিগারেশন স্থাপন করে
firebase deploy --only hosting: TARGET_NAME নির্দিষ্ট হোস্টিং সাইটের লাইভ চ্যানেলে হোস্টিং বিষয়বস্তু এবং কনফিগারেশন স্থাপন করে
আদেশ বর্ণনা
(প্রস্তাবিত নয়; emulators:start করুন)
firebase serve --only hosting
স্থানীয়ভাবে হোস্ট করা URL-এ হোস্টিং সামগ্রী এবং ডিফল্ট হোস্টিং সাইটের কনফিগারেশন পরিবেশন করে
(প্রস্তাবিত নয়; emulators:start করুন)
firebase serve --only hosting: TARGET_NAME
স্থানীয়ভাবে হোস্ট করা URL-এ হোস্টিং বিষয়বস্তু এবং নির্দিষ্ট হোস্টিং সাইটের কনফিগারেশন পরিবেশন করে