Database Tutorials Transaction Log এবং Point-in-time Recovery গাইড ও নোট

275

Transaction Log এবং Point-in-time Recovery হল ডেটাবেসের গুরুত্বপূর্ণ অংশ যা ডেটাবেসের নিরাপত্তা, অখণ্ডতা এবং রিকভারি সক্ষমতা নিশ্চিত করতে সাহায্য করে। এরা ডেটাবেসের অপারেশনগুলির পর্যবেক্ষণ এবং ডেটাবেস সিস্টেমে ত্রুটি বা সমস্যা ঘটলে সঠিক অবস্থায় ফিরে আসার প্রক্রিয়াগুলি সরবরাহ করে।


Transaction Log

Transaction Log হল একটি বিশেষ ফাইল যা ডেটাবেসের সমস্ত পরিবর্তন এবং কাজের ইতিহাস সংরক্ষণ করে। প্রতিটি ট্রানজেকশনের প্রতিটি পরিবর্তন—যেমন, ডেটা ইনসার্ট, আপডেট, অথবা ডিলিট—এগুলো লগ ফাইলে রেকর্ড হয়।

Transaction Log এর উদ্দেশ্য:

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

Transaction Log এর কার্যপ্রণালী:

  • যখন কোনো টেবিলে কোনো ডেটার পরিবর্তন ঘটে, যেমন ইনসার্ট, আপডেট, অথবা ডিলিট, তখন সেই পরিবর্তনটি ট্রানজেকশন লগে রেকর্ড হয়ে যায়।
  • ট্রানজেকশন লগ ডেটাবেসের পেছনে চলতে থাকা সমস্ত কার্যক্রমের একটি রেকর্ড রাখে, যার মাধ্যমে এটি নিশ্চিত করা হয় যে, ডেটাবেস সম্পূর্ণভাবে আপডেট এবং সিঙ্ক্রোনাইজড আছে।

উদাহরণ:

فرض করুন, একটি টেবিলের মধ্যে একটি রেকর্ড ইনসার্ট করার সময় ট্রানজেকশন লগ এভাবে রেকর্ড হবে:

BEGIN TRANSACTION;
INSERT INTO employees (name, salary) VALUES ('John', 50000);
-- Transaction Log: 'INSERT INTO employees (name, salary) VALUES ('John', 50000)'
COMMIT;

Point-in-time Recovery (PITR)

Point-in-time Recovery (PITR) হল একটি পুনরুদ্ধার প্রক্রিয়া, যা ডেটাবেসকে একটি নির্দিষ্ট সময় বা নির্দিষ্ট ট্রানজেকশন পয়েন্টে ফিরিয়ে আনে। এটি ডেটাবেস থেকে সমস্ত পরিবর্তনগুলো ফিরে নেয় এবং কেবল সেই নির্দিষ্ট সময় বা পরিস্থিতির অবস্থা পুনরুদ্ধার করে। PITR ডেটাবেসে যখন কোনো ত্রুটি বা অপব্যবহার ঘটে, তখন ডেটা খুঁজে পেতে বা পুনরুদ্ধারের জন্য ব্যবহার করা হয়।

Point-in-time Recovery এর উদ্দেশ্য:

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

Point-in-time Recovery এর কার্যপ্রণালী:

  1. ডেটাবেসের প্রতি ট্রানজেকশন বা পরিবর্তনের লগ রাখা হয়, যাতে কোনও অবস্থায় ফিরে আসা সম্ভব হয়।
  2. নির্দিষ্ট সময়ে ফিরে যাওয়ার জন্য PITR আপনাকে সংশ্লিষ্ট লগ ফাইল ব্যবহার করে সেই পয়েন্টে ফিরে যেতে সাহায্য করে।
  3. PITR প্রক্রিয়া চলাকালীন, একাধিক ট্রানজেকশন লগ পঠিত হয়, এবং নির্দিষ্ট সময় বা পয়েন্টের পরিবর্তনগুলি পুনরুদ্ধার করা হয়।

উদাহরণ:

فرض করুন, আপনার ডেটাবেসে কিছু ডেটা মুছে গেছে বা ভুল হয়েছে। আপনি যদি ৫ ঘণ্টা আগে যে অবস্থায় ছিল, সেই অবস্থায় ফিরে যেতে চান, তাহলে আপনি PITR ব্যবহার করতে পারেন।

  1. ডেটাবেসটি ব্যাকআপ করে নিন (এটি মূল ডেটা তৈরি রাখবে)।
  2. সর্বশেষ ট্রানজেকশন লগ থেকে PITR পয়েন্ট নির্বাচন করুন।
  3. PITR প্রক্রিয়ায় লগ ফাইল পড়ে, ডেটাবেসটি ৫ ঘণ্টা আগের অবস্থায় ফিরে আসবে।

Transaction Log এবং Point-in-time Recovery এর মধ্যে পার্থক্য:

ফিচারTransaction LogPoint-in-time Recovery (PITR)
মূল উদ্দেশ্যডেটাবেসের পরিবর্তন লগ করা, ডেটা রিকভারি সম্ভব করাডেটাবেসকে একটি নির্দিষ্ট সময় বা অবস্থানে ফিরিয়ে আনা
ফাইলের ধরনসাধারণত একটি নির্দিষ্ট লগ ফাইলনির্দিষ্ট সময়ে ফিরে যাওয়ার জন্য লগের একটি সিরিজ
ডেটার পরিসীমাসম্পূর্ণ ট্রানজেকশন বা পরিবর্তনের ইতিহাসনির্দিষ্ট সময়ে ফিরে আসার জন্য প্রয়োজনীয় পরিবর্তনগুলি
ব্যবহারডেটাবেসের ক্র্যাশ বা সমস্যা হলে রিকভারি, পরিবর্তন ট্র্যাকিংকোন নির্দিষ্ট সময় বা অবস্থানে ডেটাবেস ফিরিয়ে আনা
মন্তব্যসিস্টেম বা অ্যাপ্লিকেশন ব্যবহার এবং রিকভারি কার্যক্রমের জন্য অত্যন্ত গুরুত্বপূর্ণশুধুমাত্র নির্দিষ্ট সময়ে ফিরে আসার জন্য ব্যবহৃত, বিশেষত ডেটার ক্ষতি বা ভুল হলে

উপসংহার

  • Transaction Log ডেটাবেসের সমস্ত কার্যক্রম এবং পরিবর্তনের একটি রেকর্ড রাখে, যা ডেটাবেস সিস্টেমের নিরাপত্তা এবং ইনটিগ্রিটি নিশ্চিত করে।
  • Point-in-time Recovery আপনাকে ডেটাবেসকে একটি নির্দিষ্ট সময়ে ফিরিয়ে নিয়ে যেতে সাহায্য করে, যা ডেটা ক্ষতি বা ভুল হলে অপরিহার্য হয়ে ওঠে।

এই দুটি প্রক্রিয়া একে অপরের সাথে কাজ করে এবং ডেটাবেসের সর্বোচ্চ নির্ভুলতা এবং স্থিতিশীলতা নিশ্চিত করতে সহায়ক।

Content added By
Promotion

Are you sure to start over?

Loading...