mysqldump এবং অন্য টুলস ব্যবহার করে Backup নেওয়া

MySQL ডেটাবেজ ব্যাকআপ এবং রিকভারি - মাইএসকিউএল (MySQL) - Database Tutorials

252

MySQL ডেটাবেসের নিয়মিত ব্যাকআপ নেওয়া গুরুত্বপূর্ণ, কারণ এটি ডেটা ক্ষতির ক্ষেত্রে পুনরুদ্ধারের একটি নির্ভরযোগ্য উপায়। MySQL-এ ব্যাকআপ নেওয়ার জন্য সাধারণত mysqldump টুলটি ব্যবহৃত হয়, তবে আরো কিছু টুল এবং পদ্ধতি রয়েছে যা আপনি ব্যাকআপ নিতে ব্যবহার করতে পারেন।


1. mysqldump টুল দিয়ে ব্যাকআপ নেওয়া

mysqldump হলো একটি কমান্ড-লাইন টুল যা MySQL ডেটাবেসের ব্যাকআপ নেওয়ার জন্য ব্যবহৃত হয়। এটি ডেটাবেসের সঠিক স্ট্রাকচার এবং ডেটা উভয়ই ব্যাকআপ করতে সক্ষম।

mysqldump এর সাধারণ সিনট্যাক্স:

mysqldump -u username -p database_name > backup_file.sql
  • -u username: MySQL ইউজারনেম, যিনি ডেটাবেসে লগইন করবেন।
  • -p: পাসওয়ার্ড পেতে প্রম্পট করবে (এটি সরাসরি কনসোলের মাধ্যমে পাসওয়ার্ড দিতে হবে)।
  • database_name: যে ডেটাবেসের ব্যাকআপ নিতে চান।
  • backup_file.sql: যে ফাইলের মধ্যে ব্যাকআপ সংরক্ষণ হবে।

উদাহরণ:

mysqldump -u root -p my_database > /backup/my_database_backup.sql

এটি my_database নামক ডেটাবেসের ব্যাকআপ নেবে এবং /backup/my_database_backup.sql ফাইলে সংরক্ষণ করবে।

Multiple ডেটাবেস ব্যাকআপ:

একাধিক ডেটাবেসের ব্যাকআপ নিতে mysqldump এর মধ্যে সেগুলোর নাম স্পেস দিয়ে উল্লেখ করতে পারেন:

mysqldump -u root -p --databases database1 database2 > /backup/multiple_databases_backup.sql

এটি database1 এবং database2 ডেটাবেসের ব্যাকআপ নিবে।

সব ডেটাবেস ব্যাকআপ নেওয়া:

যদি আপনার সব ডেটাবেসের ব্যাকআপ নিতে চান, তবে --all-databases অপশন ব্যবহার করুন:

mysqldump -u root -p --all-databases > /backup/all_databases_backup.sql

ডেটাবেসের স্ট্রাকচার (Schema) ব্যাকআপ নেওয়া:

যদি শুধুমাত্র ডেটাবেসের কাঠামো (Structure) ব্যাকআপ নিতে চান, তবে --no-data ফ্ল্যাগ ব্যবহার করুন:

mysqldump -u root -p --no-data database_name > /backup/database_structure_backup.sql

এটি শুধুমাত্র ডেটাবেসের টেবিল এবং তার কাঠামো ব্যাকআপ করবে, কিন্তু ডেটা ব্যাকআপ করবে না।

ব্যাকআপ ডেটা পুনরুদ্ধার করা (Restore):

ব্যাকআপ ফাইল থেকে ডেটা পুনরুদ্ধার করতে:

mysql -u username -p database_name < backup_file.sql

এটি backup_file.sql ফাইল থেকে ডেটা পুনরুদ্ধার করবে।


2. MySQL Workbench দিয়ে ব্যাকআপ নেওয়া

MySQL Workbench একটি GUI টুল যা ব্যবহারকারীদের ব্যাকআপ নেওয়া এবং পুনরুদ্ধার করতে সহায়তা করে। এর মাধ্যমে আপনি সহজেই ব্যাকআপ এবং রিস্টোর অপারেশন করতে পারেন।

ব্যাকআপ নেওয়া:

  1. MySQL Workbench খুলুন এবং ডেটাবেসে কানেক্ট করুন।
  2. Server মেনু থেকে Data Export নির্বাচন করুন।
  3. আপনি যে ডেটাবেসের ব্যাকআপ নিতে চান তা নির্বাচন করুন।
  4. "Export to Dump Project Folder" অথবা "Export to Self-Contained File" নির্বাচন করুন।
  5. Start Export ক্লিক করুন।

পুনরুদ্ধার করা (Restore):

  1. Server মেনু থেকে Data Import নির্বাচন করুন।
  2. ব্যাকআপ ফাইল নির্বাচন করুন।
  3. পুনরুদ্ধারের জন্য Start Import ক্লিক করুন।

3. phpMyAdmin দিয়ে ব্যাকআপ নেওয়া

phpMyAdmin একটি জনপ্রিয় ওয়েব-ভিত্তিক GUI টুল যা MySQL ডেটাবেস ম্যানেজমেন্টের জন্য ব্যবহৃত হয়। এটি সহজেই ব্যাকআপ এবং রিস্টোর করার ব্যবস্থা করে।

ব্যাকআপ নেওয়া:

  1. phpMyAdmin এ লগইন করুন।
  2. ব্যাকআপ নিতে চান এমন ডেটাবেস নির্বাচন করুন।
  3. উপরের মেনু থেকে Export অপশন নির্বাচন করুন।
  4. Quick অথবা Custom নির্বাচন করুন (Custom এর মাধ্যমে আপনি টেবিল, ডেটা ফরম্যাট ইত্যাদি কাস্টমাইজ করতে পারবেন)।
  5. Go ক্লিক করুন এবং ব্যাকআপ ফাইল ডাউনলোড হবে।

পুনরুদ্ধার করা (Restore):

  1. Import অপশন নির্বাচন করুন।
  2. ব্যাকআপ ফাইল নির্বাচন করুন।
  3. Go ক্লিক করুন।

4. Percona XtraBackup

Percona XtraBackup হলো একটি ওপেন সোর্স টুল যা MySQL এবং MariaDB এর জন্য ব্যাকআপ তৈরি করতে ব্যবহৃত হয়। এটি hot backup ফিচার সমর্থন করে, অর্থাৎ ডেটাবেস চালু থাকা অবস্থাতেও ব্যাকআপ নেওয়া সম্ভব। এটি মূলত InnoDB ডেটাবেসের জন্য উপযুক্ত।

ব্যাকআপ নেওয়া:

xtrabackup --backup --target-dir=/path/to/backup-dir

এটি ব্যাকআপটি target-dir ডিরেক্টরিতে সংরক্ষণ করবে।

পুনরুদ্ধার করা:

xtrabackup --prepare --target-dir=/path/to/backup-dir

এটি ব্যাকআপ ফাইল প্রস্তুত করবে, তারপর আপনি পুনরুদ্ধারের জন্য MySQL সার্ভার চালু করতে পারবেন।


5. Backup-এর জন্য Cron Jobs (Linux)

আপনি cron jobs ব্যবহার করে নির্দিষ্ট সময়ে ব্যাকআপ নিতে পারেন। এতে ব্যাকআপ স্বয়ংক্রিয়ভাবে নেওয়া যাবে।

Cron Job সেটআপ:

  1. crontab -e কমান্ড দিয়ে cron job এডিট করুন।
  2. একটি ব্যাকআপ স্ক্রিপ্ট তৈরি করুন, যেমন /home/user/backup.sh, যেটি mysqldump ব্যবহার করবে।
  3. cron job এ এটি যুক্ত করুন:
0 2 * * * /bin/bash /home/user/backup.sh

এটি প্রতিদিন ২:০০ AM এ ব্যাকআপ নিবে।


সারাংশ

MySQL ডেটাবেসের ব্যাকআপ নেওয়ার জন্য বিভিন্ন পদ্ধতি ও টুল রয়েছে, যার মধ্যে mysqldump সবচেয়ে বেশি ব্যবহৃত। এটি কমান্ড লাইন টুল হিসেবে কাজ করে, তবে MySQL Workbench, phpMyAdmin, Percona XtraBackup সহ আরও GUI ও ওপেন সোর্স টুলসও রয়েছে, যা ব্যাকআপ এবং পুনরুদ্ধারের কার্যক্রমকে সহজ ও কার্যকরী করে তোলে। Cron jobs ব্যবহার করে আপনি ব্যাকআপের প্রক্রিয়াটি স্বয়ংক্রিয়ভাবে সেটআপ করতে পারেন, যা নিয়মিত ডেটাবেস ব্যাকআপ নিতে সহায়তা করে।

Content added By
Promotion

Are you sure to start over?

Loading...