স্কেল এ পড়া এবং লেখা বুঝতে

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

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

আপনার ডাটাবেসের আকার এবং ট্র্যাফিক বৃদ্ধির সাথে সাথে আপনার অ্যাপ্লিকেশনগুলি ভালভাবে কাজ করে চলেছে তা নিশ্চিত করতে, এটি ক্লাউড ফায়ারস্টোর ব্যাকএন্ডে পড়া এবং লেখার মেকানিক্স বুঝতে সহায়তা করে। আপনাকে অবশ্যই স্টোরেজ স্তরের সাথে আপনার পড়া এবং লেখার মিথস্ক্রিয়া এবং কর্মক্ষমতা প্রভাবিত করতে পারে এমন অন্তর্নিহিত সীমাবদ্ধতাগুলি বুঝতে হবে।

আপনার অ্যাপ্লিকেশন আর্কিটেক্ট করার আগে সেরা অনুশীলনের জন্য নিম্নলিখিত বিভাগগুলি দেখুন।

উচ্চ স্তরের উপাদান বুঝতে

নিম্নলিখিত চিত্রটি একটি ক্লাউড ফায়ারস্টোর API অনুরোধের সাথে জড়িত উচ্চ স্তরের উপাদানগুলিকে দেখায়৷

উচ্চ স্তরের উপাদান

ক্লাউড ফায়ারস্টোর SDK এবং ক্লায়েন্ট লাইব্রেরি

ক্লাউড ফায়ারস্টোর বিভিন্ন প্ল্যাটফর্মের জন্য SDK এবং ক্লায়েন্ট লাইব্রেরি সমর্থন করে। যদিও একটি অ্যাপ ক্লাউড ফায়ারস্টোর এপিআই-তে সরাসরি HTTP এবং RPC কল করতে পারে, ক্লায়েন্ট লাইব্রেরিগুলি API ব্যবহার সহজ করতে এবং সর্বোত্তম অনুশীলনগুলি বাস্তবায়নের জন্য বিমূর্ততার একটি স্তর সরবরাহ করে। তারা অতিরিক্ত বৈশিষ্ট্য যেমন অফলাইন অ্যাক্সেস, ক্যাশে ইত্যাদি প্রদান করতে পারে।

গুগল ফ্রন্ট এন্ড (GFE)

এটি একটি অবকাঠামো পরিষেবা যা সমস্ত Google ক্লাউড পরিষেবাগুলির জন্য সাধারণ৷ GFE আগত অনুরোধগুলি গ্রহণ করে এবং সেগুলিকে প্রাসঙ্গিক Google পরিষেবাতে (এই প্রসঙ্গে ফায়ারস্টোর পরিষেবা) ফরোয়ার্ড করে৷ এটি অন্যান্য গুরুত্বপূর্ণ কার্যকারিতা প্রদান করে, যার মধ্যে পরিষেবা অস্বীকারের আক্রমণ থেকে সুরক্ষা রয়েছে৷

ক্লাউড ফায়ারস্টোর পরিষেবা

ক্লাউড ফায়ারস্টোর পরিষেবা API অনুরোধে পরীক্ষা করে, যার মধ্যে প্রমাণীকরণ, অনুমোদন, কোটা চেক এবং নিরাপত্তা নিয়ম রয়েছে এবং লেনদেন পরিচালনা করে। এই ক্লাউড ফায়ারস্টোর পরিষেবাটিতে একটি স্টোরেজ ক্লায়েন্ট রয়েছে যা ডেটা পড়ার এবং লেখার জন্য স্টোরেজ স্তরের সাথে ইন্টারঅ্যাক্ট করে।

ক্লাউড ফায়ারস্টোর স্টোরেজ লেয়ার

ক্লাউড ফায়ারস্টোর স্টোরেজ স্তরটি ক্লাউড ফায়ারস্টোর দ্বারা সরবরাহ করা ডেটা এবং মেটাডেটা এবং সংশ্লিষ্ট ডাটাবেস বৈশিষ্ট্য উভয়ই সঞ্চয় করার জন্য দায়ী। নিম্নলিখিত বিভাগগুলি ক্লাউড ফায়ারস্টোর স্টোরেজ স্তরে ডেটা কীভাবে সংগঠিত হয় এবং কীভাবে সিস্টেম স্কেল হয় তা বর্ণনা করে৷ ডেটা কীভাবে সংগঠিত হয় সে সম্পর্কে শেখা আপনাকে একটি মাপযোগ্য ডেটা মডেল ডিজাইন করতে এবং ক্লাউড ফায়ারস্টোরের সেরা অনুশীলনগুলি আরও ভালভাবে বুঝতে সাহায্য করতে পারে।

কী রেঞ্জ এবং স্প্লিট

ক্লাউড ফায়ারস্টোর একটি NoSQL, নথি-ভিত্তিক ডাটাবেস। আপনি নথিতে ডেটা সঞ্চয় করেন, যা সংগ্রহের শ্রেণিবিন্যাসে সংগঠিত হয়। সংগ্রহের শ্রেণিবিন্যাস এবং নথি আইডি প্রতিটি নথির জন্য একটি একক কীতে অনুবাদ করা হয়। নথিগুলি এই একক কী দ্বারা যৌক্তিকভাবে সংরক্ষণ করা হয় এবং অভিধানিকভাবে আদেশ করা হয়। আমরা কী পরিসীমা শব্দটি ব্যবহার করি একটি আভিধানিকভাবে সংলগ্ন কীগুলির পরিসর বোঝাতে।

একটি সাধারণ ক্লাউড ফায়ারস্টোর ডাটাবেস একটি একক ফিজিক্যাল মেশিনে ফিট করার জন্য খুব বড়। এমন পরিস্থিতিও রয়েছে যেখানে ডেটার কাজের চাপ একটি মেশিনের পক্ষে পরিচালনা করার পক্ষে খুব ভারী। বড় কাজের চাপ সামলানোর জন্য, ক্লাউড ফায়ারস্টোর ডেটাকে আলাদা আলাদা অংশে বিভাজন করে যা একাধিক মেশিন বা স্টোরেজ সার্ভারে সংরক্ষণ এবং পরিবেশন করা যেতে পারে। এই পার্টিশনগুলি ডাটাবেস টেবিলে কী রেঞ্জের ব্লকগুলিতে তৈরি করা হয় যাকে স্প্লিট বলা হয়।

সিঙ্ক্রোনাস প্রতিলিপি

এটা মনে রাখা গুরুত্বপূর্ণ যে ডাটাবেস সবসময় স্বয়ংক্রিয়ভাবে এবং সিঙ্ক্রোনাসভাবে প্রতিলিপি করা হচ্ছে। ডেটার বিভাজনগুলির প্রতিলিপিগুলি বিভিন্ন অঞ্চলে রয়েছে যাতে সেগুলি উপলব্ধ রাখা যায় এমনকি যখন একটি অঞ্চল অ্যাক্সেসযোগ্য হয়ে ওঠে। বিভক্তের বিভিন্ন অনুলিপিতে সামঞ্জস্যপূর্ণ প্রতিলিপি ঐক্যমতের জন্য প্যাক্সোস অ্যালগরিদম দ্বারা পরিচালিত হয়। প্রতিটি বিভক্তির একটি প্রতিলিপি পক্সোস নেতা হিসাবে কাজ করার জন্য নির্বাচিত হয়, যেটি সেই বিভক্তিতে লেখাগুলি পরিচালনা করার জন্য দায়ী। সিঙ্ক্রোনাস প্রতিলিপি আপনাকে সবসময় ক্লাউড ফায়ারস্টোর থেকে ডেটার সর্বশেষ সংস্করণ পড়তে সক্ষম হওয়ার ক্ষমতা দেয়।

এর সামগ্রিক ফলাফল হল একটি পরিমাপযোগ্য এবং অত্যন্ত উপলব্ধ সিস্টেম যা পড়া এবং লেখা উভয়ের জন্যই কম বিলম্ব প্রদান করে, ভারী কাজের চাপ এবং খুব বড় পরিসরে।

ডেটা লেআউট

ক্লাউড ফায়ারস্টোর একটি স্কিমলেস ডকুমেন্ট ডাটাবেস। যাইহোক, অভ্যন্তরীণভাবে এটি তার স্টোরেজ লেয়ারে দুটি রিলেশনাল ডাটাবেস-স্টাইল টেবিলে প্রাথমিকভাবে ডেটা রাখে:

  • ডকুমেন্ট টেবিল: ডকুমেন্ট এই টেবিলে সংরক্ষণ করা হয়।
  • সূচীপত্রের সারণী: সূচী এন্ট্রি যা দক্ষতার সাথে ফলাফল পাওয়া সম্ভব করে এবং সূচকের মান অনুসারে সাজানো হয় সেগুলি এই টেবিলে সংরক্ষিত হয়।

নিম্নলিখিত চিত্রটি দেখায় যে ক্লাউড ফায়ারস্টোর ডাটাবেসের জন্য টেবিলগুলি বিভক্তগুলির সাথে কেমন হতে পারে৷ বিভক্তগুলি তিনটি ভিন্ন অঞ্চলে প্রতিলিপি করা হয় এবং প্রতিটি বিভাজনের জন্য একটি নির্ধারিত প্যাক্সোস নেতা থাকে।

ডেটা লেআউট

একক অঞ্চল বনাম বহু-অঞ্চল

যখন আপনি একটি ডাটাবেস তৈরি করেন, আপনাকে অবশ্যই একটি অঞ্চল বা বহু-অঞ্চল নির্বাচন করতে হবে।

একটি একক আঞ্চলিক অবস্থান হল একটি নির্দিষ্ট ভৌগলিক অবস্থান, যেমন us-west1 । একটি ক্লাউড ফায়ারস্টোর ডাটাবেসের ডেটার বিভাজন নির্বাচিত অঞ্চলের বিভিন্ন অঞ্চলে প্রতিলিপি রয়েছে, যেমনটি আগে ব্যাখ্যা করা হয়েছে।

একটি মাল্টি-রিজিওন অবস্থানে এমন অঞ্চলগুলির একটি সংজ্ঞায়িত সেট থাকে যেখানে ডাটাবেসের প্রতিলিপিগুলি সংরক্ষণ করা হয়। ক্লাউড ফায়ারস্টোরের একটি বহু-অঞ্চল স্থাপনায়, দুটি অঞ্চলে ডাটাবেসের সম্পূর্ণ ডেটার সম্পূর্ণ প্রতিলিপি রয়েছে৷ একটি তৃতীয় অঞ্চলে একটি সাক্ষী প্রতিরূপ রয়েছে যা ডেটার সম্পূর্ণ সেট বজায় রাখে না, তবে প্রতিলিপিতে অংশ নেয়। একাধিক অঞ্চলের মধ্যে ডেটা প্রতিলিপি করে, একটি সমগ্র অঞ্চল হারিয়ে গেলেও ডেটা লেখা এবং পড়ার জন্য উপলব্ধ।

একটি অঞ্চলের অবস্থান সম্পর্কে আরও তথ্যের জন্য, ক্লাউড ফায়ারস্টোর অবস্থানগুলি দেখুন।

একক অঞ্চল বনাম বহু-অঞ্চল

ক্লাউড ফায়ারস্টোরে লেখার জীবন বুঝুন

একটি ক্লাউড ফায়ারস্টোর ক্লায়েন্ট একটি একক নথি তৈরি, আপডেট বা মুছে ডেটা লিখতে পারে। একটি একক নথিতে লেখার জন্য সঞ্চয়স্থান স্তরে পারমাণবিকভাবে নথি এবং এর সম্পর্কিত সূচক এন্ট্রি উভয়ই আপডেট করা প্রয়োজন। ক্লাউড ফায়ারস্টোর একাধিক রিড এবং/অথবা এক বা একাধিক নথিতে লেখা সমন্বিত পারমাণবিক ক্রিয়াকলাপগুলিকে সমর্থন করে।

সব ধরনের লেখার জন্য, ক্লাউড ফায়ারস্টোর রিলেশনাল ডাটাবেসের ACID বৈশিষ্ট্য (পরমাণু, সামঞ্জস্য, বিচ্ছিন্নতা এবং স্থায়িত্ব) প্রদান করে। ক্লাউড ফায়ারস্টোরও ক্রমিকযোগ্যতা প্রদান করে, যার অর্থ সমস্ত লেনদেন একটি সিরিয়াল ক্রমে সম্পাদিত হওয়ার মতো দেখায়৷

একটি লিখিত লেনদেনের উচ্চ-স্তরের পদক্ষেপ

ক্লাউড ফায়ারস্টোর ক্লায়েন্ট যখন পূর্বে উল্লিখিত যেকোন পদ্ধতি ব্যবহার করে একটি লিখন বা একটি লেনদেন করে, অভ্যন্তরীণভাবে এটি স্টোরেজ স্তরে একটি ডাটাবেস রিড-রাইট লেনদেন হিসাবে সম্পাদিত হয়। লেনদেনটি ক্লাউড ফায়ারস্টোরকে পূর্বে উল্লিখিত ACID বৈশিষ্ট্যগুলি প্রদান করতে সক্ষম করে৷

একটি লেনদেনের প্রথম ধাপ হিসাবে, ক্লাউড ফায়ারস্টোর বিদ্যমান নথিটি পড়ে, এবং নথি টেবিলের ডেটাতে করা মিউটেশনগুলি নির্ধারণ করে৷

এর মধ্যে নিম্নরূপ সূচী সারণীতে প্রয়োজনীয় আপডেট করা অন্তর্ভুক্ত:

  • নথিতে যে ক্ষেত্রগুলি যোগ করা হচ্ছে সেগুলির জন্য ইনডেক্স টেবিলে সংশ্লিষ্ট সন্নিবেশ প্রয়োজন৷
  • যে ক্ষেত্রগুলি নথিগুলি থেকে সরানো হচ্ছে সেগুলির জন্য সূচী সারণীতে সংশ্লিষ্ট মুছে ফেলা দরকার৷
  • নথিতে যে ক্ষেত্রগুলি পরিবর্তন করা হচ্ছে, সেগুলির জন্য ইনডেক্স টেবিলে মুছে ফেলা (পুরানো মানগুলির জন্য) এবং সন্নিবেশ (নতুন মানগুলির জন্য) উভয়ই প্রয়োজন৷

পূর্বে উল্লিখিত মিউটেশনগুলি গণনা করতে, ক্লাউড ফায়ারস্টোর প্রকল্পের জন্য ইন্ডেক্সিং কনফিগারেশন পড়ে। ইন্ডেক্সিং কনফিগারেশন একটি প্রকল্পের জন্য সূচী সম্পর্কে তথ্য সঞ্চয় করে। ক্লাউড ফায়ারস্টোর দুটি ধরণের সূচক ব্যবহার করে: একক-ক্ষেত্র এবং যৌগিক। ক্লাউড ফায়ারস্টোরে তৈরি সূচীগুলির বিস্তারিত বোঝার জন্য, ক্লাউড ফায়ারস্টোরে সূচকের প্রকারগুলি দেখুন।

একবার মিউটেশনগুলি গণনা করা হলে, ক্লাউড ফায়ারস্টোর একটি লেনদেনের মধ্যে সেগুলি সংগ্রহ করে এবং তারপরে এটি করে।

স্টোরেজ লেয়ারে একটি লেখার লেনদেন বুঝুন

যেমনটি আগে আলোচনা করা হয়েছে, ক্লাউড ফায়ারস্টোরে একটি লেখার সাথে স্টোরেজ স্তরে একটি রিড-রাইট লেনদেন জড়িত। ডেটা লেআউটের উপর নির্ভর করে, একটি লেখার মধ্যে এক বা একাধিক বিভাজন থাকতে পারে যেমন ডেটা লেআউটে দেখা যায়।

নিম্নলিখিত চিত্রে, ক্লাউড ফায়ারস্টোর ডাটাবেসের একটি একক জোনে তিনটি আলাদা স্টোরেজ সার্ভারে হোস্ট করা আটটি স্প্লিট (1-8 চিহ্নিত) রয়েছে এবং প্রতিটি বিভাজন 3টি (বা তার বেশি) বিভিন্ন অঞ্চলে প্রতিলিপি করা হয়েছে৷ প্রতিটি বিভাজনের একটি প্যাক্সোস নেতা থাকে, যা বিভিন্ন বিভাজনের জন্য একটি ভিন্ন জোনে থাকতে পারে।

ক্লাউড ফায়ারস্টোর ডাটাবেস বিভক্ত

একটি ক্লাউড ফায়ারস্টোর ডাটাবেস বিবেচনা করুন যেখানে নিম্নরূপ Restaurants সংগ্রহ রয়েছে:

রেস্টুরেন্ট সংগ্রহ

ক্লাউড ফায়ারস্টোর ক্লায়েন্ট priceCategory ক্ষেত্রের মান আপডেট করে Restaurant সংগ্রহের একটি নথিতে নিম্নলিখিত পরিবর্তনের জন্য অনুরোধ করে।

সংগ্রহে থাকা একটি নথিতে পরিবর্তন করুন

নিম্নলিখিত উচ্চ-স্তরের পদক্ষেপগুলি লেখার অংশ হিসাবে কী ঘটে তা বর্ণনা করে:

  1. একটি রিড-রাইট লেনদেন তৈরি করুন।
  2. স্টোরেজ লেয়ার থেকে ডকুমেন্ট টেবিল থেকে Restaurants সংগ্রহে restaurant1 ডকুমেন্ট পড়ুন।
  3. ইনডেক্স টেবিল থেকে নথির জন্য সূচী পড়ুন।
  4. ডেটাতে করা মিউটেশনগুলি গণনা করুন। এই ক্ষেত্রে, পাঁচটি মিউটেশন রয়েছে:
    • M1: priceCategory ক্ষেত্রের মান পরিবর্তন প্রতিফলিত করতে ডকুমেন্ট টেবিলে restaurant1 এর জন্য সারি আপডেট করুন।
    • M2 এবং M3: ইনডেক্স টেবিলে priceCategory ক্যাটাগরির পুরানো মানের জন্য সারিগুলি মুছুন ইনডেক্সের অবরোহ এবং ঊর্ধ্বে।
    • M4 এবং M5: সূচী সারণীতে priceCategory নতুন মানের জন্য সারিগুলি সন্নিবেশ করান সূচী অবরোহ ও ঊর্ধ্বে।
  5. এই মিউটেশন কমিট.

ক্লাউড ফায়ারস্টোর পরিষেবার স্টোরেজ ক্লায়েন্ট সেই স্প্লিটগুলি দেখে যা পরিবর্তন করার জন্য সারিগুলির কীগুলির মালিক৷ আসুন একটি কেস বিবেচনা করি যেখানে স্প্লিট 3 M1 পরিবেশন করে এবং স্প্লিট 6 M2-M5 পরিবেশন করে। অংশগ্রহণকারী হিসাবে এই সমস্ত বিভাজন জড়িত একটি বিতরণ লেনদেন আছে। অংশগ্রহণকারী বিভাজন অন্য কোনো বিভাজনও অন্তর্ভুক্ত করতে পারে যেখান থেকে পঠন-লিখতে লেনদেনের অংশ হিসেবে ডেটা আগে পড়া হয়েছিল।

কমিটের অংশ হিসাবে কী ঘটে তা নিম্নলিখিত পদক্ষেপগুলি বর্ণনা করে:

  1. স্টোরেজ ক্লায়েন্ট একটি কমিট জারি করে। কমিটটিতে M1-M5 মিউটেশন রয়েছে।
  2. স্প্লিট 3 এবং 6 এই লেনদেনের অংশগ্রহণকারী। অংশগ্রহণকারীদের মধ্যে একজনকে সমন্বয়কারী হিসাবে নির্বাচিত করা হয়, যেমন স্প্লিট 3। সমন্বয়কারীর কাজ হল সমস্ত অংশগ্রহণকারীদের মধ্যে লেনদেন হয় কমিট বা পারমাণবিকভাবে বাতিল করা হয় তা নিশ্চিত করা।
    • এই বিভাজনগুলির নেতা প্রতিলিপিগুলি অংশগ্রহণকারীদের এবং সমন্বয়কারীদের দ্বারা সম্পন্ন কাজের জন্য দায়ী।
  3. প্রতিটি অংশগ্রহণকারী এবং সমন্বয়কারী তাদের নিজ নিজ প্রতিলিপি সহ একটি Paxos অ্যালগরিদম চালায়।
    • নেতা প্রতিলিপিগুলির সাথে একটি প্যাক্সোস অ্যালগরিদম চালান। কোরাম অর্জিত হয় যদি বেশিরভাগ প্রতিলিপি লিডারের কাছে প্রতিক্রিয়া ok to commit
    • প্রতিটি অংশগ্রহণকারী তারপর সমন্বয়কারীকে অবহিত করে যখন তারা প্রস্তুত হয় (দুই-পর্যায়ের প্রতিশ্রুতির প্রথম পর্যায়)। যদি কোনো অংশগ্রহণকারী লেনদেন করতে না পারে, তাহলে পুরো লেনদেন aborts
  4. একবার সমন্বয়কারী জানে যে সমস্ত অংশগ্রহণকারীরা, নিজে সহ, প্রস্তুত, এটি সমস্ত অংশগ্রহণকারীদের কাছে accept লেনদেনের ফলাফলের সাথে যোগাযোগ করে (দুই-পর্যায়ের প্রতিশ্রুতির দ্বিতীয় পর্যায়)। এই পর্যায়ে, প্রতিটি অংশগ্রহণকারী স্থিতিশীল সঞ্চয়স্থানের প্রতিশ্রুতিবদ্ধ সিদ্ধান্ত রেকর্ড করে এবং লেনদেন প্রতিশ্রুতিবদ্ধ হয়।
  5. সমন্বয়কারী ক্লাউড ফায়ারস্টোরে স্টোরেজ ক্লায়েন্টকে উত্তর দেয় যে লেনদেন করা হয়েছে। সমান্তরালভাবে, সমন্বয়কারী এবং সমস্ত অংশগ্রহণকারীরা ডেটাতে মিউটেশনগুলি প্রয়োগ করে।

প্রতিশ্রুতিবদ্ধ জীবনচক্র

যখন ক্লাউড ফায়ারস্টোর ডাটাবেস ছোট হয়, তখন এটি ঘটতে পারে যে একটি একক বিভাজন M1-M5 মিউটেশনের সমস্ত কীগুলির মালিক। এই ধরনের ক্ষেত্রে, লেনদেনে শুধুমাত্র একজন অংশগ্রহণকারী থাকে এবং পূর্বে উল্লিখিত দুই-পর্যায়ের প্রতিশ্রুতির প্রয়োজন হয় না, এইভাবে লেখাগুলি দ্রুততর হয়।

বহু-অঞ্চলে লেখেন

একটি বহু-অঞ্চল স্থাপনায়, অঞ্চল জুড়ে প্রতিলিপিগুলির বিস্তার প্রাপ্যতা বাড়ায়, কিন্তু কার্যক্ষমতার খরচ সহ আসে। বিভিন্ন অঞ্চলে প্রতিলিপিগুলির মধ্যে যোগাযোগের জন্য দীর্ঘ রাউন্ড ট্রিপ সময় লাগে। তাই, ক্লাউড ফায়ারস্টোর অপারেশনগুলির জন্য বেসলাইন লেটেন্সি একক অঞ্চলের স্থাপনার তুলনায় সামান্য বেশি।

আমরা প্রতিলিপিগুলিকে এমনভাবে কনফিগার করি যাতে বিভাজনের নেতৃত্ব সর্বদা প্রাথমিক অঞ্চলে থাকে। ক্লাউড ফায়ারস্টোর সার্ভারে যেখান থেকে ট্রাফিক ইনকাম করা হয় সেটি হল প্রাথমিক অঞ্চল। নেতৃত্বের এই সিদ্ধান্ত ক্লাউড ফায়ারস্টোরে স্টোরেজ ক্লায়েন্ট এবং রেপ্লিকা লিডার (বা মাল্টি-বিভক্ত লেনদেনের জন্য সমন্বয়কারী) মধ্যে যোগাযোগের রাউন্ড-ট্রিপ বিলম্বকে কমিয়ে দেয়।

ক্লাউড ফায়ারস্টোরের প্রতিটি লেখার সাথে ক্লাউড ফায়ারস্টোরের রিয়েল-টাইম ইঞ্জিনের সাথে কিছু মিথস্ক্রিয়াও জড়িত। রিয়েল-টাইম কোয়েরি সম্পর্কে আরও তথ্যের জন্য, স্কেলে রিয়েল-টাইম কোয়েরি বুঝতে দেখুন।

ক্লাউড ফায়ারস্টোরে পড়ার জীবনকে বুঝুন

এই বিভাগটি ক্লাউড ফায়ারস্টোরে স্বতন্ত্র, নন-রিয়েলটাইম পঠনগুলির মধ্যে পড়ে। অভ্যন্তরীণভাবে, ক্লাউড ফায়ারস্টোর সার্ভার দুটি প্রধান পর্যায়ে এই প্রশ্নগুলির বেশিরভাগ পরিচালনা করে:

  1. সূচী সারণীতে একটি একক পরিসর স্ক্যান
  2. আগের স্ক্যানের ফলাফলের উপর ভিত্তি করে ডকুমেন্ট টেবিলে পয়েন্ট লুকআপ
ক্লাউড ফায়ারস্টোরে এমন কিছু প্রশ্ন থাকতে পারে যার জন্য কম প্রক্রিয়াকরণ বা বেশি প্রক্রিয়াকরণের প্রয়োজন (উদাহরণস্বরূপ, IN কোয়েরি)।

স্টোরেজ লেয়ার থেকে পড়া ডেটা অভ্যন্তরীণভাবে একটি ডাটাবেস লেনদেন ব্যবহার করে করা হয় যাতে ধারাবাহিকভাবে পড়া নিশ্চিত করা যায়। যাইহোক, লেখার জন্য ব্যবহৃত লেনদেনের বিপরীতে, এই লেনদেন লক লাগে না। পরিবর্তে, তারা একটি টাইমস্ট্যাম্প বেছে নিয়ে কাজ করে, তারপর সেই টাইমস্ট্যাম্পে সমস্ত পঠন সম্পাদন করে। যেহেতু তারা লকগুলি অর্জন করে না, তাই তারা একযোগে পড়া-লেখার লেনদেনগুলিকে ব্লক করে না। এই লেনদেনটি চালানোর জন্য, ক্লাউড ফায়ারস্টোরের স্টোরেজ ক্লায়েন্ট একটি টাইমস্ট্যাম্প বাউন্ড নির্দিষ্ট করে, যা স্টোরেজ স্তরকে বলে যে কীভাবে একটি রিড টাইমস্ট্যাম্প বেছে নিতে হয়। ক্লাউড ফায়ারস্টোরে স্টোরেজ ক্লায়েন্ট দ্বারা বেছে নেওয়া টাইমস্ট্যাম্পের ধরনটি রিড রিকোয়েস্টের রিড অপশন দ্বারা নির্ধারিত হয়।

স্টোরেজ লেয়ারে একটি পঠিত লেনদেন বুঝুন

এই বিভাগটি ক্লাউড ফায়ারস্টোরের স্টোরেজ লেয়ারে পড়ার ধরন এবং কীভাবে সেগুলি প্রক্রিয়া করা হয় তা বর্ণনা করে।

দৃঢ় পড়া

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

একক বিভক্ত পড়া

ক্লাউড ফায়ারস্টোরের স্টোরেজ ক্লায়েন্ট পড়ার জন্য সারিগুলির কীগুলির মালিকানাধীন বিভক্তগুলি সন্ধান করে৷ আসুন ধরে নিই যে এটিকে পূর্ববর্তী বিভাগ থেকে স্প্লিট 3 থেকে পড়তে হবে। রাউন্ড ট্রিপ লেটেন্সি কমাতে ক্লায়েন্ট নিকটতম প্রতিলিপিতে পড়ার অনুরোধ পাঠায়।

এই মুহুর্তে, নির্বাচিত প্রতিরূপের উপর নির্ভর করে নিম্নলিখিত ক্ষেত্রে ঘটতে পারে:

  • রিড রিকোয়েস্ট লিডার রেপ্লিকাতে যায় (জোন এ)।
    • যেহেতু নেতা সবসময় আপ টু ডেট থাকে, তাই পড়া সরাসরি এগিয়ে যেতে পারে।
  • পড়ার অনুরোধ একটি নন-লিডার রেপ্লিকাতে যায় (যেমন, জোন বি)
    • স্প্লিট 3 এর অভ্যন্তরীণ অবস্থার দ্বারা জানতে পারে যে এটিকে পড়ার জন্য যথেষ্ট তথ্য রয়েছে এবং বিভক্তটি তা করে।
    • স্প্লিট 3 সর্বশেষ তথ্য দেখেছে কিনা তা নিশ্চিত নয়। এটি পঠিত পরিবেশন করার জন্য আবেদন করার জন্য প্রয়োজনীয় শেষ লেনদেনের টাইমস্ট্যাম্পটি চাইতে নেতাকে একটি বার্তা পাঠায়। একবার সেই লেনদেনটি প্রয়োগ করা হলে, পড়া এগিয়ে যেতে পারে।

ক্লাউড ফায়ারস্টোর তারপরে তার ক্লায়েন্টকে প্রতিক্রিয়া ফেরত দেয়।

মাল্টি-বিভক্ত পড়া

যে পরিস্থিতিতে একাধিক বিভাজন থেকে রিডগুলি করতে হয়, একই প্রক্রিয়া সমস্ত বিভাজন জুড়ে ঘটে। একবার সমস্ত বিভক্ত থেকে ডেটা ফেরত দেওয়া হলে, ক্লাউড ফায়ারস্টোরের স্টোরেজ ক্লায়েন্ট ফলাফলগুলিকে একত্রিত করে। ক্লাউড ফায়ারস্টোর তারপর এই ডেটা দিয়ে তার ক্লায়েন্টকে সাড়া দেয়।

বাসি পড়ে

ক্লাউড ফায়ারস্টোরে স্ট্রং রিড হল ডিফল্ট মোড। যাইহোক, এটি নেতার সাথে প্রয়োজনীয় যোগাযোগের কারণে সম্ভাব্য উচ্চ বিলম্বের খরচে আসে। প্রায়শই আপনার ক্লাউড ফায়ারস্টোর অ্যাপ্লিকেশনটির ডেটার সর্বশেষ সংস্করণ পড়ার প্রয়োজন হয় না এবং কার্যকারিতা এমন ডেটার সাথে ভালভাবে কাজ করে যা কয়েক সেকেন্ডের বাসি হতে পারে।

এই ধরনের ক্ষেত্রে, ক্লায়েন্ট read_time রিড বিকল্পগুলি ব্যবহার করে পুরানো রিডগুলি গ্রহণ করতে বেছে নিতে পারে। এই ক্ষেত্রে, পঠন করা হয় যেহেতু ডেটাটি read_time এ ছিল, এবং নিকটতম প্রতিলিপিটি ইতিমধ্যেই নির্দিষ্ট read_time এ ডেটা রয়েছে তা যাচাই করে নেওয়ার সম্ভাবনা বেশি। লক্ষণীয়ভাবে ভাল পারফরম্যান্সের জন্য, 15 সেকেন্ড একটি যুক্তিসঙ্গত অচলতার মান। এমনকি বাসি পাঠের জন্যও, সারি পাওয়া যায় একে অপরের সাথে সামঞ্জস্যপূর্ণ।

হটস্পট এড়িয়ে চলুন

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

সঞ্চয়স্থান এবং লোডকে বিভক্ত করতে সময় লাগে এবং খুব দ্রুত ট্র্যাফিক র‌্যাম্পিং করা উচ্চ বিলম্ব বা সময়সীমা অতিক্রম করার ত্রুটির কারণ হতে পারে, সাধারণভাবে হটস্পট হিসাবে উল্লেখ করা হয়, যখন পরিষেবাটি সামঞ্জস্য করে। প্রতি সেকেন্ডে 500টি ক্রিয়াকলাপ সহ একটি ডাটাবেসের সংগ্রহে ট্র্যাফিক বৃদ্ধি করার সময় সর্বোত্তম অনুশীলনটি কী পরিসর জুড়ে অপারেশনগুলি বিতরণ করা। এই ধীরে ধীরে র‌্যাম্প আপ করার পরে, প্রতি পাঁচ মিনিটে 50% পর্যন্ত ট্রাফিক বাড়ান। এই প্রক্রিয়াটিকে 500/50/5 নিয়ম বলা হয় এবং আপনার কাজের চাপ মেটাতে সর্বোত্তমভাবে স্কেল করার জন্য ডাটাবেসকে অবস্থান করে।

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

কন্টেন্ট ত্রুটি ঘটবে যখন একাধিক ক্রিয়াকলাপ একই সাথে একই নথি পড়ার এবং/বা লেখার চেষ্টা করে।

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

মনে রাখবেন যে উপরে বর্ণিত অনুশীলনগুলি অনুসরণ করে, Firestore আপনাকে কোনো কনফিগারেশন সামঞ্জস্য না করেই ইচ্ছামত বড় কাজের চাপ পরিবেশন করতে পারে।

সমস্যা সমাধান

ফায়ারস্টোর একটি ডায়াগনস্টিক টুল হিসাবে কী ভিজ্যুয়ালাইজার প্রদান করে যা বিশেষভাবে ব্যবহারের ধরণগুলি বিশ্লেষণ করতে এবং হটস্পটিং সমস্যাগুলির সমস্যা সমাধানের জন্য ডিজাইন করা হয়েছে৷

এরপর কি