২৬ সেপ, ২০২৩·4 মিনিট পড়তে

কিভাবে MVCC রিলেশনাল ডাটাবেসে কাজ করে

রিলেশনাল ডাটাবেসে মাল্টিভারসন কনকারেন্সি কন্ট্রোল (MVCC) এর ধারণা, মূল ডাটাবেস সিস্টেমে এর বাস্তবায়ন এবং কীভাবে এটি ডেটা সামঞ্জস্যতা নিশ্চিত করে এবং কর্মক্ষমতা বাড়ায় তা অন্বেষণ করুন৷

কিভাবে MVCC রিলেশনাল ডাটাবেসে কাজ করে

মাল্টিভারসন কনকারেন্সি কন্ট্রোল (MVCC) এর ভূমিকা

আধুনিক ডাটাবেস সিস্টেমে, একযোগে একাধিক লেনদেন ঘটতে পারে এমন পরিবেশে ডেটা সামঞ্জস্য এবং কর্মক্ষমতা নিশ্চিত করার জন্য একযোগে গুরুত্বপূর্ণ। রিলেশনাল ডাটাবেসে সঙ্গতি পরিচালনার জন্য একটি দক্ষ কৌশল হল মাল্টিভারসন কনকারেন্সি কন্ট্রোল (MVCC)। এই পদ্ধতিটি রেকর্ডের পৃথক সংস্করণ বজায় রাখে, পাঠকদের চলমান লেখার ক্রিয়াকলাপ দ্বারা অবরুদ্ধ না হয়ে একটি সামঞ্জস্যপূর্ণ ডাটাবেস স্ন্যাপশট অ্যাক্সেস করার অনুমতি দেয়।

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

MVCC ওয়ার্কফ্লো: রেকর্ড তৈরি করা, আপডেট করা এবং মুছে ফেলা

MVCC কীভাবে কাজ করে তা বোঝার জন্য, আমরা একটি সিস্টেমে রেকর্ড তৈরি, আপডেট এবং মুছে ফেলার প্রক্রিয়ার মধ্য দিয়ে যাব যা এই একযোগে নিয়ন্ত্রণ কৌশল প্রয়োগ করে।

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

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

MVCC আপসাইডস এবং ডাউনসাইডস: ভারসাম্য কর্মক্ষমতা এবং ধারাবাহিকতা

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

MVCC এর আপসাইডস

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

MVCC এর খারাপ দিক

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

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

MVCC ব্যবহার করে জনপ্রিয় রিলেশনাল ডাটাবেস সিস্টেম

বেশ কিছু জনপ্রিয় রিলেশনাল ডাটাবেস ম্যানেজমেন্ট সিস্টেম (RDBMS) MVCC ব্যবহার করে উন্নত সঙ্গতি এবং কর্মক্ষমতা অপ্টিমাইজেশানের জন্য। এখানে MVCC প্রয়োগকারী বহুল ব্যবহৃত কিছু সিস্টেমের একটি ওভারভিউ রয়েছে।

পোস্টগ্রেএসকিউএল

নেতৃস্থানীয় ওপেন-সোর্স রিলেশনাল ডাটাবেস সিস্টেমগুলির মধ্যে একটি, PostgreSQL , কার্যকরভাবে লেনদেনগুলিকে আলাদা করতে, সঙ্গতি অপ্টিমাইজ করতে এবং ডেটা সামঞ্জস্য নিশ্চিত করতে MVCC সমর্থন করে৷ PostgreSQL একটি স্ন্যাপশট আইসোলেশন কৌশল ব্যবহার করে যা পঠন এবং লেখার লেনদেনগুলিকে আলাদা করে এবং প্রতিটি লেনদেনের জন্য বিভিন্ন ডেটা স্ন্যাপশট বজায় রাখে। এই পদ্ধতিটি লক বিরোধ কমায় এবং দেরি না করে একাধিক লেনদেন একই সাথে চালানোর অনুমতি দেয়।

মাইএসকিউএল (ইনোডিবি স্টোরেজ ইঞ্জিন)

মাইএসকিউএল আরেকটি জনপ্রিয় ওপেন সোর্স রিলেশনাল ডাটাবেস সিস্টেম। যদিও MyISAM-এর ডিফল্ট স্টোরেজ ইঞ্জিন MVCC সমর্থন করে না, InnoDB স্টোরেজ ইঞ্জিন, যেটি বেশিরভাগ ব্যবহারের ক্ষেত্রেও সুপারিশ করা হয়, কর্মক্ষমতা এবং সঙ্গতি উন্নত করতে MVCC প্রয়োগ করে। InnoDB ব্যবহার করার সময়, MySQL রেকর্ডের একাধিক সংস্করণ রক্ষণাবেক্ষণ করে যাতে একযোগে পড়া এবং লেখার ক্রিয়াকলাপ করা যায়, যার ফলে লক কন্টেন্ট কম হয় এবং কর্মক্ষমতা উন্নত হয়।

ওরাকল

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

মাইক্রোসফট এসকিউএল সার্ভার (স্ন্যাপশট আইসোলেশন লেভেল)

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

AppMaster সাথে এমভিসিসি: কনকারেন্সি কন্ট্রোলের সুবিধা নেওয়া

MVCC-সঙ্গত অ্যাপ তৈরি করুন
ব্যাকএন্ড হাতে কোডিং না করেই একযোগে ব্যবহারকারীদের সামলাতে সক্ষম একটি PostgreSQL অ্যাপ তৈরি করুন.
AppMaster চেষ্টা করুন

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

AppMaster ভিজ্যুয়াল ডেভেলপমেন্ট টুলস ডেভেলপারদেরকে ডেটা স্কিমা মডেল এবং ডিজাইন করতে, REST API তৈরি করতে এবং ওয়েব এবং মোবাইল অ্যাপ্লিকেশন ইন্টারফেস ডিজাইন করতে সক্ষম করে যা রিলেশনাল ডাটাবেসের সাথে নির্বিঘ্নে কাজ করে। অ্যাপমাস্টার-জেনারেট করা অ্যাপ্লিকেশনগুলি প্রাথমিক ডেটা স্টোরেজ হিসাবে যেকোনো PostgreSQL-সামঞ্জস্যপূর্ণ ডাটাবেসের সাথে কাজ করে, নিশ্চিত করে যে ডেভেলপাররা PostgreSQL-এ MVCC ব্যবহার করতে পারেন।

AppMaster এর প্ল্যাটফর্ম Go (golang), Vue3 ফ্রেমওয়ার্ক ব্যবহার করে ওয়েব অ্যাপ্লিকেশন এবং Android এর জন্য Kotlin এবং Jetpack Compose এবং iOS-এর জন্য SwiftUI ব্যবহার করে মোবাইল অ্যাপ্লিকেশনগুলির জন্য ব্যাকএন্ড অ্যাপ্লিকেশনগুলির জন্য সোর্স কোড তৈরি করে। ব্যবসায়িক যুক্তি দক্ষতার সাথে বাস্তবায়িত হওয়ার সাথে সাথে, আপনার অ্যাপ্লিকেশনটি পারফরম্যান্ট এবং অপ্টিমাইজড পদ্ধতিতে ডাটাবেসের সাথে ইন্টারঅ্যাক্ট করতে পারে যখন একযোগে নিয়ন্ত্রণের জন্য MVCC-এর সুবিধাগুলি ব্যবহার করে।

ভবিষ্যতের প্রবণতা এবং উদ্ভাবন

কিছু মিনিটে নিরাপদ অ্যাক্সেস নিশ্চিত করুন
প্রি-বিল্ট অথেনটিকেশন মডিউল ব্যবহার করুন যাতে আপনি ডেটা ও ট্রানজ্যাকশনে ফোকাস করতে পারেন.
অথেনটিকেশন যোগ করুন

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

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

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

উপসংহার

মাল্টিভারসন কনকারেন্সি কন্ট্রোল (MVCC) হল রিলেশনাল ডাটাবেস ম্যানেজমেন্ট সিস্টেমের একটি গুরুত্বপূর্ণ কৌশল যাতে ডেটা সামঞ্জস্যতা নিশ্চিত করা যায়, লক কনটেন্টেশন কমানো যায় এবং একাধিক একযোগে লেনদেনের সাথে পরিস্থিতিতে কর্মক্ষমতা অপ্টিমাইজ করা যায়। PostgreSQL, MySQL (InnoDB), Oracle, এবং Microsoft SQL Server (স্ন্যাপশট আইসোলেশন লেভেল) সহ বেশ কিছু সুপরিচিত ডাটাবেস সিস্টেম, উন্নত সমবায় ব্যবস্থাপনার জন্য MVCC প্রয়োগ করে।

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

প্রশ্নোত্তর

মাল্টিভারসন কনকারেন্সি কন্ট্রোল (MVCC) কি?

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

কিভাবে MVCC কাজ করে?

MVCC ডাটাবেসে রেকর্ডের একাধিক সংস্করণ রেখে কাজ করে। এটি লেনদেনের জন্য অনন্য আইডি (লেনদেন আইডি) বরাদ্দ করে এবং যখন একটি লেনদেন শুরু হয় তখন শুরু হয়। যখন একটি লেনদেন একটি রেকর্ড তৈরি করে, আপডেট করে বা মুছে দেয়, তখন ডাটাবেস সেই রেকর্ডের একটি নতুন সংস্করণ তৈরি করে, লেনদেনের আইডির সাথে ট্যাগ করা হয়। পাঠকরা লেনদেনের শুরুর সময়ের উপর ভিত্তি করে উপযুক্ত সংস্করণটি পড়ার মাধ্যমে ধারাবাহিক স্ন্যাপশট অ্যাক্সেস করতে পারেন।

MVCC এর সুবিধা কি?

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

MVCC এর ত্রুটিগুলি কি কি?

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

কোন রিলেশনাল ডাটাবেস সিস্টেম এমভিসিসি বাস্তবায়ন করে?

পোস্টগ্রেএসকিউএল, মাইএসকিউএল (ইনোডিবি স্টোরেজ ইঞ্জিন সহ), ওরাকল এবং মাইক্রোসফ্ট এসকিউএল সার্ভার (স্ন্যাপশট আইসোলেশন লেভেল সহ) সহ বেশ কয়েকটি জনপ্রিয় রিলেশনাল ডাটাবেস সিস্টেম মাল্টিভারসন কনকারেন্সি কন্ট্রোল (এমভিসিসি) ব্যবহার করে।

অ্যাপমাস্টার কিভাবে কনকারেন্সি কন্ট্রোল পরিচালনা করে?

AppMaster প্ল্যাটফর্ম ডেভেলপারদের এমন অ্যাপ্লিকেশন তৈরি করতে দেয় যা MVCC ব্যবহার করে রিলেশনাল ডাটাবেসের সাথে নির্বিঘ্নে ইন্টারঅ্যাক্ট করে। AppMaster অপ্টিমাইজেশানগুলি অফার করে যাতে আপনার অ্যাপ্লিকেশন দক্ষতার সাথে ডাটাবেসের সাথে ইন্টারঅ্যাক্ট করতে পারে এবং সামঞ্জস্য নিয়ন্ত্রণ এবং কার্য সম্পাদনের জন্য MVCC এর ক্ষমতার সম্পূর্ণ সুবিধা গ্রহণ করতে পারে।

শুরু করা সহজ
কিছু আশ্চর্যজনকতৈরি করুন

বিনামূল্যের পরিকল্পনা সহ অ্যাপমাস্টারের সাথে পরীক্ষা করুন।
আপনি যখন প্রস্তুত হবেন তখন আপনি সঠিক সদস্যতা বেছে নিতে পারেন৷

এবার শুরু করা যাক