ضرورت استفاده از طرح پشتيبان در سازمانها

چرا استفاده از طرح پشتیبان برای سازمانها یک ضرورت است؟

 طرح پشتیبان چیست؟

قبل از هر چیز بهتر است بدانیم طرح پشتیبان یا Backup  به چه معناست؟ در دانش فناوری اطلاعات، Backup یا عمل Backup گیری اشاره به تهیه کپی‌هایی از اطلاعات دارد. این نسخه های کپی شده معمولا برای بازگرداندن اطلاعات هنگام آسیب دیدن و یا مفقود شدن اطلاعات اصلی بکار میروند .فرض کنید که دریک سازمان، وظیفه تهیه نسخه پشتیبان را برعهده شما گذاشته‌اند. از آنجاییکه Backup گیری به روشها و با استراتژیهای مختلف و با تنظیمات مختلف بصورت خودکار قابل پیاده سازی است کاربر این امکان را دارد که بتواند با برنامه­ریزی مشخص و قابل کنترل، Backupگیری را انجام دهد. چرا که دامنه انتخاب روش Backupگیری متنوع است و فرد مسئول باید براساس امکانات موجود، بهترین روش با بالاترین بازده و کمترین ریسک را انتخاب کند.

در واقع Backup Plan  امکانی را برای کاربر فراهم میاورد که بتواند دربازه زمانی مشخص و با انتخاب استراتژیهای تعریف شده، یک نسخه Backup  از دیتابیس را در تاریخهای تنظیم شده و در مسیر مشخص، تهیه کند.

ضرورت استفاده از طرح پشتیبان (backup plan) در سازمانها

  • ضرورت پشتیبان گیری

هر فردی در طول زندگی‌اش ممکن است چیزهایی را گم کند. ممکن است پولتان را از دست بدهید، راهتان را گم کنید! خب، کامپیوتر هم احتمال دارد چیزی را فراموش یا گم کند. تا بحال تصور کرده‌اید که ممکن است روزی سرور سازمان شما قفل کرده و همه اطلاعات ضروریتان از بین برود و هیچ راهی برای بازگرداندن آنها نداشته باشید؟ این اتفاق میتواند برای شما بسیار وحشتناک و طاقت فرسا باشد. در سطح خیلی کوچک فرض کنید درآخرین ماههای تحصیل در دانشکده هستید و زمان زیادی بر روی پایان نامه‌نان کار کرده‌اید. در حال کار روی فایل پایان‌نامه هستید که با یک صفحه سیاه روبرو میشوید که نوشته شده: درایو C وجود ندارد! نابودی چندین گیگابایت اطلاعات، به معنی بر باد رفتن چند سال گزارش و تکالیف و مقالات و اسناد خواهد بود. حال این اتفاق را به یک سازمان بزرگ تعمیم دهید و وسعت تبعات منفی آنرا تجسم کنید.

  • ضرورت استفاده از طرح پشتیبان

جدای از مبحث ضرورت پشتیبان‌گیری از دیتابیس، شما بعنوان فرد مسئول در سازمان باید یک استراتژی و خط مشی مناسب برای بکاپ‌گیری تان طراحی کنید. هر چه که زمان میگذرد، افراد و شرکتها با حجم بالا و غیر قابل کنترلی از اطلاعات روبرو میشوند، که منظم‌سازی و دسته‌بندی آنها روز به روز سختتر شده و مهمتر اینکه بدون حمایت لازم رها شده‌اند. با این تفاسیر مهمترین نکته در پشتیبان‌گیری، برنامه‌ریزی برای یک استراتژی صحیح و کارآمد است، تا در گذر زمان و با بالا رفتن حجم اطلاعات، کارایی لازم را داشته باشد.

بعنوان جمعبندی برخی از ضرورت­های استفاده از طرح پشتیبان عبارتند از:

  • ﮔﻢ ﺷﺪﻥ ﻳﺎ ﺣﺬﻑ ﺷﺪﻥ ﺍﻃﻼﻋﺎﺕ
  • بازگرداندن به نسخه قبلی بعد از تغییرات اعمال شده
  • هزینه بر بودن تولید مجدد اطلاعات در صورت حذف شدن آنها
  • غیرممکن بودن بازگردانی اطلاعات در برخی موارد

تااینجای مقاله، امیدوارم توانسته باشم شما را نسبت به ضرورت پشتیبان‌گیری متقاعد کنم. با این توضیحات، به نظر من همین امروز هم برای تهیه نسخه پشتیبان دیر است! همین الان باید اقدام کنید.

 روشهای backup گیری از اطلاعات

  • Full Backup

معمولترین روش Backup گیری از SQL Server  روش Full یا Complete میباشد. به این روش Database Backup هم گفته میشود. در این نوعBackup گیری از کلیهDatabase های موجود برروی Instance شما بهمراه هم Transaction Log های موجود در آن Backup گرفته میشود و با این روش شما براحتی میتوانید اطلاعات خود را Recover یا بازیابی کنید. این روش ساده‌ترین روش بازیابی اطلاعات میباشد زیرا تمامی اطلاعات بیکباره بازیابی میشوند.

Full Backup

  • Differential Backup

یکی دیگر ازروشهای معمولBackup گیری، روش معروف Differential است .در این روش فقط از تغییراتی که در Databaseهای شما از آخرین Backup گرفته شده انجام شده است، Backup گرفته میشود. طبیعی است که اگر از Database های شما تاکنون Backup گرفته نشده باشد در اولین باری که بصورت Differential بکاپ بگیرید تمامی اطلاعات Database ها Backup گرفته می شوند.

پس همانطور که عنوان هم کردیم اگر شما یک Full Backup بگیرید و سپس یک Differential Backup بگیرید محتویات موجود در Differential Backup شما فقط شامل اطلاعات تغییر کرده بعد از Full Backup میباشد که در واقع همان اطلاعات [۱] Extentها هستند. زمانیکه میخواهیدBackup ی از SQL سرور خود را بازیابی کنید کافیست ضمن بازگردانی آخرین Full Backup  فقط اطلاعات موجود در آخرین Differential Backup را نیز بازیابی کنید تا اطلاعات کامل بازیابی شود. در این حالت سایر Differential Backup های موجود نادیده گرفته می شوند.

روش Differential Backup

  • Log Backup

اگر Recovery Model پایگاه داده‌های شما در حالت Full یا Bulk-Logged قرار داشته باشد بنابراین شما میتوانید از Transaction Log های خود نیز Backup بگیرید. اگر شما در ساختار خود Transaction Log Backup را دیده باشید و به همراه آن Full Backup نیز داشته باشید قادر خواهید بود چیزی شبیه به Restore Point ویندوز را برای SQL سرور ایجاد کنید بدین معنا که اگر شخصی بصورت تصادفی کلیه اطلاعات موجود در Database های شما را حذف کند، شما میتوانید با استفاده از اینBackup ها اطلاعات را بحالت عملیاتی قبل از حذف اطلاعات بازیابی کنید. نکته منفی که در خصوص Log Backup ها وجود دارد این است که اگر Recovery Model شما به حالت Bulk-Logged قرار گرفته باشد شما برای بازیابی مجبور هستید کل Transaction Log های موجود را بازیابی کنیدLog Backup ها در واقع همان Transaction Log Backup ها هم هستند، این نوع Backup به شما اجازه میدهد که بتوانید از بخش فعال Transaction Log ها Backup بگیرید. در اینصورت زمانیکه شما از اطلاعات خود یک Full یا Differential Backup می گیرید، Transaction Log Backup تمامی اطلاعاتی که بعد از گرفتن این Backup ها ایجاد شده اند را نیز Backup میگیرد. زمانیکه دستور گرفتن Transaction Log Backup صادر شد فضایی که توسط Transaction Log ها اشغال شده بود آزاد و میتوان از آن برای سایر فرآیندهای سیستم استفاده کرد اما اگر شما Transaction Log Backup نگیرید حجم این Log ها همینطور اضافه خواهد شد و رشد خواهد کرد.

  • File Backup

یکی دیگر از گزینه‌هایی که برای Backup گیری از SQL سرور وجود دارد به File Backup معروف است. این روش به شما امکان این را میدهد که بتوانید بجای اینکه کل Database را Backup بگیرید هر فایل را بصورت مستقل Backup بگیرید. البته این روش زمانی صادق است که شما چندین فایل Data در Database خود ساخته باشید. یکی از دلایل مهم استفاده از این روش Backup گیری زمانیست که شما یک Database دارید که دارای چندین فایل با حجمهای زیاد است و میخواهید هر کدام از این فایل ها را بصورت جداگانه و مستقل Backup بگیرید. توجه کنید که در بیشتر موارد شما فقط یک فایل در Database خود دارید و این روش معمولا به کار شما نمیاید. این نوع Backup معمولا در محیطهای Enterprise ای انجام میشود که واقعا حجم عظیمی از اطلاعات در آن وجود دارد.

  • Filegroup Backup

شما می توانید برای فایلهای موجود در Database خود file group درست کنید، علاوه بر اینکه شما میتوانید با استفاده از روش قبلی که File Backup بود از فایلهای مجازی موجود در Database خود Backup بگیرید. میتوانید از این file group ها که به تعریف فارسی، گروه فایلها میباشند نیز Backup بگیرید. بصورت پیشفرض در یک Database یک عدد file group اصلی یا PRIMARY file group وجود دارد که به فایل Data ای که ایجاد شده است گره میخورد. تاکید کردیم که شما میتوانید از هر file group ها بصورت جداگانه و مستقل Backup بگیرید، بزرگترین مزیتی که file group Backup ها نسبت به file Backup ها دارند این است که شما میتوانید file group های خود را بصورت فقط خواندنی یا Read Only بکاپ بگیرید این بدین معناست که نمیتوان این اطلاعات را دستکاری کرد و صرفا میتوان آنرا خواند. شما میتوانید بجای اینکه از همه Databaseهای خود Backup بگیرید تنها در وهله‌های زمانی معین از نسخه‌های خواندنی و نوشتنی یا Read Write مربوط به file group ها Backup بگیرید.

  • Copy Only Backup

زمانیکه شما از روش Copy Only Backup برای Backup گیری Database ها استفاده میکنید تقریبا Backup ای شبیه به Full Backup گرفته‌اید که در آن تمامی اطلاعات موجود در Database ها وLog ها و سایر موارد مرتبط وجود دارد، اما این سئوال پیش میاید که واقعا تفاوت Full و Copy در چه چیزی است ؟ تفاوت در این است که در صورتیکه شما از Database های خود Full Backup بگیرید Plan بکاپ گیری Differential و تغییراتی که در Database ها انجام شده است تغییر میکند اما در حالت Copy Only هیج تغییری در Backup Plan شما پیش نمیاید و صرفا یک کپی با تمام مشخصات از اطلاعات برداشت میشود، در اصطلاح فنی Copy Only Backup ها Log Chain یا زنجیرهLog های شما را که برای برنامه‌ریزی Backup های دیگر استفاده میشود را تغییر نمیدهند. معمولا اینگونه backup ها بصورت دستی و برای موارد بررسی و تحلیلی استفاده می شود اما به هر حال بد نیست هر چند وقت یکبار بصورت دستی اینکار را انجام دهید.

  • Mirror Backup

از این نوع روش Backup گیری بعنوان Database Mirroring نیز یاد میشود، در این روش همانطور که از نامش پیداست بمعنی بکاپ‌گیری آینه‌ای است، بدین صورت که از این نوع روش Backup گیری بیشتر برای بالابردن دسترسی‌پذیری یا Availability  پایگاه‌های داده استفاده می‌شود، شما در این روش نیازمند حداقل دو سرور مجزا هستید که بتوانند Database های خود را با همدیگر Synchronize کنند. روش Backup گیری Mirroring بر اساس هر Database انجام میشود و در اصطلاح فنی به آن Per Database Basis گفته میشود ، توجه کنید که این روش صرفا با Full Recovery Model کار میکند. در این روش Backup گیری، بعد از راه‌اندازی سرویس اگر هر اطلاعاتی در Database ها ثبت شود بلافاصله با Database دیگر که بر روی سرور دیگری قرار دارد Replicate  و یکپارچه‌سازی می‌شود.

روش Mirror Backup

 طرح پشتیبان (Backup plan) فراگستر

با توجه به کاربرد و مشخصات هر یک از انواع روشهای تهیه نسخه پشتیبان در SQL Server، طرح موثر و بهینه برای تهیه نسخه پشتیبان میتواند تلفیقی از هریک از روش‌های فوق الذکر باشد. از این طریق اهدافی چون کاهش مدت زمان تهیه نسخ پشتیبان، کاهش حجم نسخ پشتیبان در طول هفته و کاهش احتمال از دست رفتن اطلاعات در شرایط بروز حوادث محقق میگردد.

توصیه­های فراگستر در انتخاب Plan  مناسب

شرکت فراگستر در انتخاب Backup Plan سلیقه مشتریان و امکانات آنها را در نظر میگیرد. چرا که مشتری، خود صاحب دیتابیس است و میتواند در باب این موضوع اعمال سلیقه انجام دهد. اگر چه شرکت فراگستر پیشنهادات منطقی و اصولی کار را به مشتری بنا بر پارامترهای زیر انجام خواهد داد.

  1. حجم تغییرات داده در بانک اطلاعاتی
  2. ظرفیت بانک اطلاعات
  3. ارزش و اهمیت داده های بانک اطلاعاتی در چه سطحی است
  4. چه اندازه فضای نگهداری برای Backup ها موجود است.
  5. مدت زمان مورد نیاز برای Backup از دیتابیس
  6. آیا اگر سرورتان منفجر شود داشتن Backup تا چند لحظه قبل از انفجار برایتان اهمیت دارد.

در جدول زیر استراتژی پیشنهادی شرکت فراگستر جهت تهیه نسخ پشتیبان ارائه میگردد. لازم به ذکر است این پیشنهاد صرفاً بصورت یک نمونه و بدون در نظر گرفتن تعداد کاربران و شرایط خاص هر یک از مشتریان عنوان شده است و هر مشتری میبایست ضمن بررسی و تحلیل شرایط و توانمندیهای خود نسبت به تهیه و اجرای استراتژی مناسب اقدام نماید.

زمان backup گیری نوع backup گیری
هر هفته یک بار در روز جمعه در سرور Full backup
تمام روز های هفته بجز روز جمعه که Full Backup گرفته می شود. Differential Backup
هر ماه روی یک Type  و یا هارد اکسترنال خارج از محیط سرور Full backup

___________________________

[۱] Extent: در فایل‌های ویندوز یک بیت به نام Archive Bit وجود دارد که تغییر کردن یک فایل را به شما نشان می‌دهد ، همین مفهوم در SQL Server به‌عنوان extent شناخته می‌شود

0 پاسخ

دیدگاه خود را ثبت کنید

Want to join the discussion?
Feel free to contribute!

Got Something To Say: