Transaction Logging এবং Recovery

Transactions in HSQLDB - এইচএসকিউএলডিবি (HSQLDB) - Database Tutorials

296

HSQLDB-তে Transaction Logging এবং Recovery ডেটাবেসের ডেটা সুরক্ষা এবং ধারাবাহিকতা বজায় রাখার একটি গুরুত্বপূর্ণ অংশ। Transaction Logging ডেটাবেসে প্রতিটি ট্রানজেকশনের কার্যক্রম রেকর্ড করে, যা ডেটা লস বা ডেটা দুর্নীতির পরিস্থিতিতে পুনরুদ্ধারে সাহায্য করে। Recovery প্রক্রিয়া ব্যর্থতার পরে ডেটাবেসকে একটি নির্ভরযোগ্য অবস্থায় ফিরিয়ে আনে।


Transaction Logging

Transaction Logging হল একটি প্রক্রিয়া যা ডেটাবেসে প্রতিটি পরিবর্তনের একটি লজ তৈরি করে। এটি ব্যর্থতার ক্ষেত্রে ডেটা পুনরুদ্ধারের জন্য একটি গুরুত্বপূর্ণ উপাদান।

প্রধান বৈশিষ্ট্য

  • প্রতিটি ট্রানজেকশনের কার্যক্রম (INSERT, UPDATE, DELETE) একটি লজ ফাইলে রেকর্ড হয়।
  • লজ ফাইলগুলি ডেটাবেসের স্থায়িত্ব এবং ধারাবাহিকতা নিশ্চিত করে।
  • ব্যর্থতার পরে পুনরুদ্ধারে ব্যবহৃত হয়।

HSQLDB-তে Transaction Logging
HSQLDB-তে Transaction Logging সক্রিয় করতে hsqldb.log_data প্যারামিটার ব্যবহার করা হয়।

SET DATABASE DEFAULT TABLE TYPE CACHED;
SET DATABASE TRANSACTION CONTROL LOG;

লজ ফাইল ফরম্যাট

  • .log ফাইল: প্রতিটি ট্রানজেকশনের বিবরণ সংরক্ষণ করে।
  • .script ফাইল: ডেটাবেসের বর্তমান অবস্থার স্ক্রিপ্ট।
  • .properties ফাইল: ডেটাবেস কনফিগারেশন সংরক্ষণ করে।

Recovery

Recovery প্রক্রিয়াটি ব্যর্থতা (যেমন পাওয়ার ব্যর্থতা, সার্ভার ক্র্যাশ) পরে ডেটাবেস পুনরুদ্ধার করতে ব্যবহৃত হয়। HSQLDB-তে Recovery প্রক্রিয়া লজ ফাইল এবং স্ক্রিপ্ট ফাইল ব্যবহার করে সম্পন্ন হয়।

Recovery প্রক্রিয়ার ধাপসমূহ

  1. Checkpoints

    • HSQLDB নির্দিষ্ট সময় পরপর চেকপয়েন্ট তৈরি করে।
    • চেকপয়েন্টে ডেটাবেসের বর্তমান অবস্থা .script ফাইলে সংরক্ষণ করা হয়।
    CHECKPOINT DEFRAG;
    
  2. Redo Logs
    • ব্যর্থতার পরে, .log ফাইলের সাহায্যে পেন্ডিং ট্রানজেকশন সম্পন্ন করা হয়।
    • এটি নিশ্চিত করে যে ট্রানজেকশনের কোন ধাপ বাদ পড়েনি।
  3. Undo Logs
    • অসম্পূর্ণ ট্রানজেকশনগুলি .log ফাইল থেকে ফিরিয়ে নেওয়া হয়।
    • এটি নিশ্চিত করে যে ডেটাবেস সঠিক অবস্থায় ফিরে আসে।
  4. Database Validation
    • ডেটাবেস স্ট্রাকচার এবং ডেটা চেক করা হয়।
    • অসম্পূর্ণ বা ক্ষতিগ্রস্ত ডেটা সরানো হয়।

Configuration for Logging and Recovery in HSQLDB

HSQLDB-তে Transaction Logging এবং Recovery কার্যকর করার জন্য নিম্নলিখিত সেটিংস নিশ্চিত করুন:

Configuration Example

hsqldb.tx=mvcc
hsqldb.log_data=true
hsqldb.write_delay=false

Checkpoints Schedule

SET DATABASE CHECKPOINT DEFRAG;

Log Management

  • অপ্রয়োজনীয় লজ ফাইল মুছে ফেলা:

    SHUTDOWN COMPACT;
    

Transaction Logging এবং Recovery এর উপকারিতা

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

সারাংশ

Transaction Logging এবং Recovery HSQLDB-এর একটি অবিচ্ছেদ্য অংশ, যা ডেটাবেসের নির্ভরযোগ্যতা এবং ধারাবাহিকতা বজায় রাখতে সাহায্য করে। লজ ফাইল ব্যবহার করে ট্রানজেকশন রেকর্ড করা এবং ব্যর্থতার পরে ডেটা পুনরুদ্ধার নিশ্চিত করা HSQLDB-কে একটি স্থিতিশীল এবং নিরাপদ ডেটাবেস সিস্টেমে পরিণত করেছে।

Content added By
Promotion

Are you sure to start over?

Loading...