MongoDB Data Backup কৌশল গাইড ও নোট

Database Tutorials - মঙ্গোডিবি (MongoDB) - MongoDB Backup এবং Restore
359

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

এখানে MongoDB ডেটা ব্যাকআপের প্রধান কৌশলগুলি আলোচনা করা হলো:


1. mongodump এবং mongorestore টুলস ব্যবহার

MongoDB এর সাথে অন্তর্নিহিত দুটি কমান্ড-লাইন টুল রয়েছে: mongodump (ব্যাকআপ নেওয়ার জন্য) এবং mongorestore (ব্যাকআপ পুনরুদ্ধারের জন্য)। এগুলি MongoDB ডেটাবেসের ব্যাকআপ এবং পুনরুদ্ধারের জন্য সবচেয়ে সাধারণ এবং ব্যবহারযোগ্য টুল।

mongodump (ব্যাকআপ নেওয়া)

mongodump কমান্ড MongoDB ডেটাবেসের ব্যাকআপ তৈরি করতে ব্যবহৃত হয়। এটি ডেটাবেসের পুরো কপি BSON ফরম্যাটে তৈরি করে।

  • একটি ডেটাবেসের ব্যাকআপ:

    mongodump --db=your_database_name --out=/path/to/backup/folder
    
  • বিশেষ একটি কালেকশনের ব্যাকআপ:

    mongodump --db=your_database_name --collection=your_collection_name --out=/path/to/backup/folder
    
  • MongoDB Atlas থেকে ব্যাকআপ নেওয়া: MongoDB Atlas এ সংযুক্ত হলে, আপনি --uri ফ্ল্যাগ ব্যবহার করে সার্ভারের URI দিয়ে ব্যাকআপ নিতে পারেন:

    mongodump --uri="mongodb+srv://<username>:<password>@cluster0.mongodb.net/your_database_name" --out=/path/to/backup/folder
    

mongorestore (ব্যাকআপ পুনরুদ্ধার করা)

mongorestore কমান্ড ব্যাকআপের BSON ফাইলগুলি MongoDB ডেটাবেসে পুনরুদ্ধার করতে ব্যবহৃত হয়।

  • ব্যাকআপ পুনরুদ্ধার:

    mongorestore --db=your_database_name /path/to/backup/folder/your_database_name
    
  • বিশেষ একটি কালেকশনের ব্যাকআপ পুনরুদ্ধার:

    mongorestore --db=your_database_name --collection=your_collection_name /path/to/backup/folder/your_database_name/your_collection_name.bson
    

2. MongoDB Atlas Backup

MongoDB Atlas একটি ক্লাউড ভিত্তিক MongoDB সার্ভিস, যা ডেটাবেস ব্যাকআপের জন্য প্রোফেশনাল এবং স্বয়ংক্রিয় সমাধান প্রদান করে। MongoDB Atlas তে ব্যাকআপ ফিচারটি অটোমেটিক এবং হাই অ্যাভেইলেবিলিটি সাপোর্ট করে।

MongoDB Atlas Automated Backups:

MongoDB Atlas তে ব্যাকআপ স্বয়ংক্রিয়ভাবে সেট করা হয়, এবং আপনি কাস্টম ব্যাকআপ ইন্টারভ্যাল সেট করতে পারেন। MongoDB Atlas এর Backups সেকশনে গিয়ে, ব্যাকআপের ধরন এবং পুনরুদ্ধারের সময় নির্ধারণ করা যায়।

  • Continuous Backups: MongoDB Atlas ডেটাবেসের প্রতি মিনিটে স্বয়ংক্রিয়ভাবে ব্যাকআপ নেয়।
  • Snapshot Backups: স্ন্যাপশট ব্যাকআপ নিয়মিত ইন্টারভ্যাল ভিত্তিতে নেওয়া হয়, যেমন প্রতি ঘণ্টায় বা প্রতি দিন।

3. File System Snapshot Backup

MongoDB ডেটাবেসের ব্যাকআপ নেওয়ার আরেকটি কৌশল হল ফাইল সিস্টেম স্ন্যাপশট ব্যাকআপ। এটি ডেটাবেসের ডেটা ফাইলের স্ন্যাপশট নিয়ে ডেটাবেসের ব্যাকআপ তৈরি করে। এই পদ্ধতি বিশেষত MongoDB এর জন্য অনেক দ্রুত ব্যাকআপ নিতে সহায়তা করে, তবে এটি নির্দিষ্ট শর্তে কাজ করে (যেমন MongoDB সার্ভারকে শাটডাউন করতে হতে পারে অথবা ডেটাবেসকে রিড-অনলি মোডে রাখতে হতে পারে)।

File System Snapshot:

  • লাইভ ব্যাকআপ: MongoDB এর একটি লাইভ ব্যাকআপ নিতে হলে, ডেটাবেসের স্ন্যাপশট নেয়া এবং ব্যাকআপের সময় MongoDB এর fsync এবং lock কমান্ড ব্যবহার করতে হয়।
  • Snapshot তৈরি: MongoDB ডেটাবেস সার্ভারের ডেটা ডিরেক্টরির একটি স্ন্যাপশট তৈরি করুন।

4. Logical Backup (Export/Import)

MongoDB তে mongoexport এবং mongoimport টুল ব্যবহার করে আপনি ডেটাবেসের ডেটার লজিক্যাল ব্যাকআপ নিতে পারেন। এই পদ্ধতিতে ডেটা CSV বা JSON ফরম্যাটে এক্সপোর্ট এবং ইমপোর্ট করা হয়।

mongoexport (ডেটা এক্সপোর্ট)

  • ডেটা এক্সপোর্ট করা (JSON ফরম্যাট):

    mongoexport --db=your_database_name --collection=your_collection_name --out=/path/to/backup/file.json
    
  • CSV ফরম্যাটে এক্সপোর্ট করা:

    mongoexport --db=your_database_name --collection=your_collection_name --type=csv --fields="field1,field2,field3" --out=/path/to/backup/file.csv
    

mongoimport (ডেটা ইমপোর্ট)

  • ডেটা পুনরুদ্ধার করা:

    mongoimport --db=your_database_name --collection=your_collection_name --file=/path/to/backup/file.json
    

5. Backup Retention and Scheduling

MongoDB ডেটাবেসের ব্যাকআপ রাখতে হলে, ব্যাকআপ রিটেনশন (সংরক্ষণ) এবং শিডিউল সেটআপ করা প্রয়োজন। MongoDB সিস্টেমে ব্যাকআপের জন্য নিম্নলিখিত পদ্ধতি গ্রহণ করা যেতে পারে:

  • ব্যাকআপ রিটেনশন পলিসি: একটি নির্দিষ্ট সময় পর পুরানো ব্যাকআপ ডিলিট করতে হবে (যেমন, এক সপ্তাহের পুরানো ব্যাকআপ ডিলিট করা)। এতে স্টোরেজ সাশ্রয় হয়।
  • ব্যাকআপ শিডিউল: MongoDB Atlas এ ব্যাকআপের শিডিউল করা হয়, যা নির্দিষ্ট সময় পর ব্যাকআপ নেয়। MongoDB সার্ভার সেটআপের জন্য cron job ব্যবহার করতে পারেন।

সারাংশ

MongoDB ডেটাবেসের ব্যাকআপ নেওয়ার জন্য বিভিন্ন কৌশল রয়েছে, যেমন mongodump/mongorestore টুল ব্যবহার, MongoDB Atlas Backup, File System Snapshot, এবং Logical Export/Import। MongoDB তে ব্যাকআপ নিতে হলে সঠিক কৌশল নির্বাচন করা প্রয়োজন, যা ডেটাবেসের আকার, লোড এবং সিস্টেমের পারফরম্যান্স অনুযায়ী উপযুক্ত হবে। ব্যাকআপ নেওয়া ডেটাবেসের নিরাপত্তা নিশ্চিত করে এবং বিপর্যয়ের সময় ডেটা পুনরুদ্ধার সহজ করে তোলে।

Content added By
Promotion

Are you sure to start over?

Loading...