
উৎপাদন ব্যবস্থায় রেডিসের ব্যবহার বৃদ্ধি পাওয়ার সাথে সাথে দলগুলি অবশেষে একটি সমালোচনামূলক স্থাপত্য সিদ্ধান্তের সম্মুখীন হয়। রেডিস কি রেডিস সেন্টিনেল বা রেডিস ক্লাস্টার ব্যবহার করে স্কেল করা উচিত?
এই সিদ্ধান্তটি প্রায়ই দেরিতে নেওয়া হয়, এবং চাপের মধ্যে, সাধারণত কর্মক্ষমতা সমস্যা, স্মৃতি ক্লান্তি বা উপলব্ধতার ঘটনাগুলি উপস্থিত হওয়ার পরে। দুর্ভাগ্যবশত, রেডিস সেন্টিনেল এবং রেডিস ক্লাস্টার খুব ভিন্ন সমস্যার সমাধান করে, এবং ভুল একটি বেছে নেওয়ার ফলে বেদনাদায়ক পুনরায় ডিজাইন করা হয়।
রেডিস সেন্টিনেল প্রাপ্যতা সম্পর্কে। রেডিস ক্লাস্টার স্কেলেবিলিটি সম্পর্কে। দুটিকে বিভ্রান্ত করা রেডিস আর্কিটেকচারের সবচেয়ে সাধারণ ভুলগুলির মধ্যে একটি।
সেন্টিনেলের মূল সমস্যাটি আবার সমাধান করে
Redis Sentinel একটি একক Redis ডেটাসেটের জন্য উচ্চ প্রাপ্যতা প্রদান করার জন্য ডিজাইন করা হয়েছে।
এর প্রাথমিক দায়িত্বগুলি হল:
-
রেডিস মাস্টার এবং রেপ্লিকা নোড নিরীক্ষণ
-
ব্যর্থতা সনাক্তকরণ
-
স্বয়ংক্রিয় ব্যর্থতা সঞ্চালন
-
নতুন মাস্টার সম্পর্কে ক্লায়েন্টদের আপডেট করা হচ্ছে
রেডিস সেন্টিনেল ডেটা ভাগ করে না। এখনও ঠিক একটি লজিক্যাল রেডিস ইন্সট্যান্স সব কী ধারণ করে আছে।
যদি মাস্টার ব্যর্থ হয়, সেন্টিনেল একটি প্রতিরূপ প্রচার করে। একটি অ্যাপ্লিকেশনের দৃষ্টিকোণ থেকে, রেডিস ন্যূনতম বাধার সাথে কাজ চালিয়ে যাচ্ছে।
কিভাবে রেডিস সেন্টিনেল অভ্যন্তরীণভাবে কাজ করে
একটি সাধারণ রেডিস সেন্টিনেল সেটআপের মধ্যে রয়েছে:
-
একজন রেডিস মাস্টার
-
এক বা একাধিক রেডিস প্রতিলিপি
-
একাধিক সেন্টিনেল প্রক্রিয়া তাদের নিরীক্ষণ করে
সেন্টিনেলরা ক্রমাগত মাস্টারের স্বাস্থ্য পরীক্ষা করে। যখন সেন্টিনেলদের একটি কোরাম সম্মত হয় যে মাস্টার ডাউন, একটি ব্যর্থতা ট্রিগার হয়।
একটি প্রতিলিপিকে মাস্টার হিসাবে উন্নীত করা হয় এবং বাকি প্রতিলিপিগুলিকে অনুসরণ করার জন্য পুনরায় কনফিগার করা হয়৷
মূল পয়েন্ট হল যে ডেটা একই আকার এবং আকৃতি রয়ে গেছে। কীগুলির কোনও পুনর্বন্টন নেই৷
৷রেডিস সেন্টিনেল কি করে না
রেডিস সেন্টিনেল করে না:
-
একটি একক নোডের বাইরে মেমরির ক্ষমতা বাড়ান
-
এক কোরের বাইরে লেখার থ্রুপুট বাড়ান
-
সংক্ষিপ্ত বা বিতরণ ডেটা
যদি আপনার Redis ইন্সট্যান্স মেমরি বা CPU ফুরিয়ে যায়, সেন্টিনেল যোগ করা সাহায্য করে না। সেন্টিনেল রেডিসকে উপলব্ধ রাখে, বড় নয়।
কোর সমস্যা রিডিস ক্লাস্টার সমাধান করে
রেডিস ক্লাস্টার একা উপলব্ধতার পরিবর্তে স্কেলেবিলিটির ঠিকানা দেয়৷
এটি সমাধান করে:
-
একটি একক মেশিনের মেমরি সীমা
-
একক-থ্রেডেড এক্সিকিউশন দ্বারা সৃষ্ট থ্রুপুট সীমা
রেডিস ক্লাস্টার একাধিক মাস্টার নোড জুড়ে ডেটা শার্ড করে। প্রতিটি মাস্টার কীস্পেসের একটি উপসেটের মালিক।
প্রাপ্যতার জন্য প্রতিলিপি ব্যবহার করা হয়, তবে শার্ডিং হল সংজ্ঞায়িত বৈশিষ্ট্য।
কিভাবে রেডিস ক্লাস্টার একটি উচ্চ স্তরে কাজ করে
রেডিস ক্লাস্টার কীস্পেসকে 16,384টি হ্যাশ স্লটে ভাগ করে।
প্রতিটি মাস্টার নোড এই স্লটের একটি অংশের মালিক। হ্যাশ ফাংশনের উপর ভিত্তি করে স্লটে কীগুলি বরাদ্দ করা হয়।
যখন একটি ক্লায়েন্ট একটি কমান্ড জারি করে, তখন এটি সেই স্লটের জন্য দায়ী নোডে পাঠানো হয়।
যদি একটি মাস্টার ব্যর্থ হয়, তার প্রতিলিপিগুলির মধ্যে একটি স্বয়ংক্রিয়ভাবে প্রচারিত হয়, সেন্টিনেলের অনুরূপ, তবে শুধুমাত্র সেই শার্ডের জন্য৷
উপলভ্যতা মডেল তুলনা
রেডিস সেন্টিনেল প্রদান করে:
-
এক সময়ে একজন সক্রিয় মাস্টার
-
একটি একক নোডে সম্পূর্ণ ডেটাসেট
-
স্বয়ংক্রিয় ব্যর্থতা
রেডিস ক্লাস্টার প্রদান করে:
-
একাধিক মাস্টার
-
নোড জুড়ে ডেটা বিতরণ করা হয়
-
শার্ড স্তরে ব্যর্থতা
সেন্টিনেল নোড ব্যর্থতা থেকে রক্ষা করে। ক্লাস্টার নোড ব্যর্থতা এবং ক্ষমতা সীমা উভয় থেকে রক্ষা করে।
স্কেলিং বৈশিষ্ট্য
রেডিস সেন্টিনেল উল্লম্বভাবে স্কেল করে।
আপনি রেডিসকে একটি বড় মেশিনে স্থানান্তর করতে পারেন, আরও মেমরি যোগ করতে পারেন, বা দ্রুত CPU ব্যবহার করতে পারেন, কিন্তু আপনি এখনও সিলিংয়ে আঘাত করছেন৷
রেডিস ক্লাস্টার স্কেল অনুভূমিকভাবে।
আপনি মেমরি এবং থ্রুপুট বাড়াতে নোড যোগ করুন। প্রতিটি নোড শুধুমাত্র ডেটাসেটের একটি অংশ পরিচালনা করে।
একবার একটি একক রেডিস নোড আর যথেষ্ট নয়, একা সেন্টিনেল অপর্যাপ্ত৷
৷অ্যাপ্লিকেশন ডিজাইনের প্রভাব
রেডিস সেন্টিনেল বেশিরভাগ অ্যাপ্লিকেশনে স্বচ্ছ।
অ্যাপ্লিকেশনগুলি এখনও মনে করে যে তারা একটি রেডিস উদাহরণের সাথে কথা বলছে। ক্লায়েন্টরা ফেইলওভারের পরে নতুন মাস্টারের সাথে পুনরায় সংযোগ করে৷
রেডিস ক্লাস্টারের জন্য ক্লাস্টার-সচেতন ক্লায়েন্ট প্রয়োজন৷
আবেদন করতে হবে:
-
পুনঃনির্দেশ পরিচালনা করুন
-
হ্যাশ স্লট সীমানাকে সম্মান করুন
-
অসমর্থিত মাল্টি-কি অপারেশন এড়িয়ে চলুন
ক্লাস্টার গ্রহণ কী ডিজাইন এবং ডেটা মডেলিংকে উল্লেখযোগ্যভাবে প্রভাবিত করে৷
মাল্টি-কী অপারেশন এবং লেনদেন
রেডিস সেন্টিনেলের সাথে:
-
সমস্ত চাবি এক মাস্টারের উপর থাকে
-
মাল্টি-কী অপারেশনগুলি সাধারণত কাজ করে
-
লেনদেন এবং লুয়া স্ক্রিপ্ট আশানুরূপ আচরণ করে
রেডিস ক্লাস্টার সহ:
-
কীগুলি বিভিন্ন নোডে থাকতে পারে
-
মাল্টি-কী অপারেশনগুলি শুধুমাত্র একই হ্যাশ স্লটের মধ্যে কাজ করে
-
ক্রস-স্লট অপারেশন ব্যর্থ হয়
এই একক পার্থক্য প্রায়ই রেডিস ক্লাস্টারে স্থানান্তরিত দলগুলির জন্য সবচেয়ে বড় ধাক্কা৷
৷অপারেশনাল জটিলতা
রেডিস সেন্টিনেল মাঝারি অপারেশনাল জটিলতার পরিচয় দেয়।
আপনি পরিচালনা করুন:
-
মাস্টার এবং প্রতিলিপি
-
সেন্টিনেল কোরাম
-
ব্যর্থ আচরণ
রেডিস ক্লাস্টার উল্লেখযোগ্যভাবে আরও জটিলতার পরিচয় দেয়।
আপনি পরিচালনা করুন:
-
একাধিক মাস্টার এবং প্রতিলিপি
-
স্লট বরাদ্দ এবং ভারসাম্য
-
ক্রিয়াকলাপ পুনরায় ভাগ করা
-
ক্লায়েন্ট সামঞ্জস্য
ক্লাস্টার শক্তিশালী অপারেশনাল শৃঙ্খলা দাবি করে।
যখন রেডিস সেন্টিনেল সঠিক পছন্দ হয়
রেডিস সেন্টিনেল একটি ভাল ফিট যখন:
-
ডেটাসেট একটি মেশিনে আরামে ফিট করে
-
একটি একক কোরের মধ্যে থ্রুপুট ফিট লিখুন
-
উচ্চ প্রাপ্যতা প্রয়োজন
-
অ্যাপ্লিকেশন লজিক মাল্টি-কী অপারেশনের উপর নির্ভর করে
একা সেন্টিনেলের সাথে অনেক সিস্টেম সফলভাবে চলে।
যখন রেডিস ক্লাস্টার সঠিক পছন্দ হয়
Redis ক্লাস্টার উপযুক্ত যখন:
-
মেমরি প্রয়োজনীয়তা একটি একক নোড অতিক্রম করে
-
থ্রুপুট চাহিদা বাড়তে থাকে
-
অনুভূমিক স্কেলিং প্রয়োজন
-
অ্যাপ্লিকেশনগুলি শার্ডিংয়ের জন্য ডিজাইন করা যেতে পারে
ক্লাস্টার একটি স্কেলিং কৌশল, শুধুমাত্র একটি ব্যর্থতা প্রক্রিয়া নয়।
সাধারণ মাইগ্রেশন ভুল
দলগুলি প্রায়ই:
-
খুব তাড়াতাড়ি রেডিস ক্লাস্টার গ্রহণ করুন
-
অনুমান করুন সেন্টিনেল এবং ক্লাস্টার বিনিময়যোগ্য
-
মূল নকশার প্রভাব উপেক্ষা করুন
-
বহু-কী সীমাবদ্ধতা খুব দেরিতে আবিষ্কার করুন
এই ভুলগুলির ফলে সাধারণত দ্রুত রিফ্যাক্টরিং হয়।
একটি সহজ সিদ্ধান্তের নিয়ম
রেডিস সেন্টিনেল ব্যবহার করুন যখন:
-
আপনি আপনার ডেটা মডেল পরিবর্তন না করে উচ্চ প্রাপ্যতা চান
Redis ক্লাস্টার ব্যবহার করুন যখন:
-
আপনাকে অবশ্যই একটি মেশিনের বাইরে রেডিস স্কেল করতে হবে
আপনি যদি ক্লাস্টার বেছে নেন, তবে এটির জন্য তাড়াতাড়ি ডিজাইন করুন, এমনকি যদি আপনি এটি অবিলম্বে সক্ষম না করেন।
সারাংশ
রেডিস সেন্টিনেল এবং রেডিস ক্লাস্টার হল পরিপূরক প্রযুক্তি যা বিভিন্ন সিস্টেমের চাপকে মোকাবেলা করে। সেন্টিনেল একটি একক ডেটাসেটের জন্য পরিষেবার ধারাবাহিকতা নিশ্চিত করে। ক্লাস্টার রেডিসকে মেশিন জুড়ে স্কেল করতে সক্ষম করে। সঠিক পদ্ধতি নির্বাচন করা নির্ভর করে প্রাপ্যতা বা মাপযোগ্যতা প্রাথমিক স্থাপত্য চালক কিনা।