انتقال فایل SQL Server مقایسه DETACH ATTACH و  ALTER DATABASE

انتقال فایل‌های دیتابیس SQL Server: مقایسه روش‌های DETACH ATTACH و  ALTER DATABASE

جابجایی فایل‌های دیتابیس SQL Server یک کار رایج برای مدیران پایگاه داده (DBA) است. دلایل مختلفی برای این کار وجود دارد، از جمله:
افزایش فضای ذخیره‌سازی: ممکن است در درایو کنونی فضای کافی وجود نداشته باشد و نیاز به انتقال فایل‌ها به درایوی با ظرفیت بیشتر باشد.
بهینه‌سازی عملکرد I/O: انتقال فایل‌ها به دیسک‌های سریع‌تر یا جداگانه می‌تواند عملکرد ورودی/خروجی (I/O) دیتابیس را بهبود بخشد.
یکپارچه‌سازی یا جداسازی دیسک‌ها: سازماندهی بهتر دیسک‌ها برای مقاصد مدیریتی یا پشتیبان‌گیری.
تغییر مسیر فایل‌ها برای AlwaysOn Availability Groups: در برخی سناریوها، تغییر مسیر فایل‌ها ممکن است برای گروه‌های همیشه فعال (AlwaysOn) ضروری باشد.

این مقاله دو روش اصلی برای جابجایی فایل‌های دیتابیس را بررسی می‌کند: استفاده از دستورات DETACH ATTACH و  ALTER DATABASE برای تغییر مسیر فایل‌ها. هر دو روش در شرایط خاص مزایا و معایب خود را دارند.

روش اول: جابجایی فایل‌های دیتابیس با DETACH/ATTACH

روش `DETACH/ATTACH` یکی از قدیمی‌ترین و شناخته‌شده‌ترین راه‌ها برای جابجایی فایل‌های دیتابیس SQL Server است. این روش شامل جدا کردن دیتابیس از نمونه SQL Server، جابجایی فیزیکی فایل‌ها و سپس اتصال مجدد دیتابیس از مکان جدید است.

مزایای روش DETACH/ATTACH:

سادگی: برای دیتابیس‌های کوچک و متوسط نسبتاً ساده است.
کاربردهای دیگر: می‌توان از آن برای انتقال دیتابیس بین سرورها یا برای تهیه کپی از دیتابیس استفاده کرد.
حداقل نیاز به فضای موقت: نیازی به فضای دیسک اضافی روی درایو مقصد برای کپی کردن فایل‌ها قبل از جابجایی نیست.

معایب روش DETACH/ATTACH:

ریسک‌پذیری بالاتر: در صورت بروز مشکل در فرآیند جابجایی یا خرابی فایل‌ها، بازیابی دیتابیس ممکن است دشوار باشد.
خطا در نام فایل‌های گزارش (Log Files): اگر نام فایل گزارش (LDF) اصلی را در هنگام `ATTACH` اشتباه وارد کنید یا آن را در مکان جدید قرار ندهید، SQL Server ممکن است فایل LDF جدیدی بسازد که در صورت خرابی، بازیابی آن به مشکل بخورد.
عدم دسترسی به دیتابیس: در تمام طول فرآیند `DETACH/ATTACH`، دیتابیس از دسترس کاربران خارج می‌شود.
عدم ردیابی تغییرات: SQL Server تغییرات مسیر فایل‌ها را ردیابی نمی‌کند و این شما هستید که باید از صحت مسیرهای جدید مطمئن شوید.

مراحل جابجایی با DETACH/ATTACH:

مرحله 1: شناسایی فایل‌های دیتابیس
قبل از شروع، باید نام‌های منطقی و مسیرهای فیزیکی تمام فایل‌های دیتابیس (MDF، NDF و LDF) را بدانید. این کار را می‌توانید با اجرای کوئری زیر انجام دهید:


SELECT name, physical_name AS CurrentLocation, state_desc
FROM sys.master_files
WHERE database_id = DB_ID('YourDatabaseName');

مرحله 2: جدا کردن دیتابیس (DETACH)
پس از شناسایی مسیرها، دیتابیس را از سرور SQL جدا کنید. این کار باعث می‌شود دیتابیس آفلاین شده و فایل‌های آن از دسترس SQL Server خارج شوند تا بتوانید آن‌ها را جابجا کنید.


USE master;
GO
EXEC sp_detach_db 'YourDatabaseName', 'true';
GO

نکته: پارامتر ‘true’ (یا 1) در `sp_detach_db` به SQL Server دستور می‌دهد که اتصال‌های فعال به دیتابیس را قطع کرده و دیتابیس را جدا کند.

مرحله 3: جابجایی فیزیکی فایل‌ها
در این مرحله، فایل‌های دیتابیس (مانند `YourDatabaseName.mdf` و `YourDatabaseName_log.ldf`) را از مسیر اصلی خود به مسیر جدید مورد نظر در سیستم عامل کپی یا منتقل کنید. این مرحله باید خارج از محیط SQL Server و در سطح سیستم عامل انجام شود.

مرحله 4: اتصال مجدد دیتابیس (ATTACH)
پس از جابجایی فایل‌ها، دیتابیس را به SQL Server متصل کنید. در این مرحله باید مسیرهای جدید فایل‌ها را مشخص کنید.


USE master;
GO
CREATE DATABASE YourDatabaseName
ON
(FILENAME = N'D:\NewPath\YourDatabaseName.mdf'),
(FILENAME = N'D:\NewPath\YourDatabaseName_log.ldf')
FOR ATTACH;
GO

این دستور دیتابیس را با استفاده از فایل‌های موجود در مسیرهای جدید به سرور متصل می‌کند.

روش دوم: جابجایی فایل‌های دیتابیس با ALTER DATABASE

روش `ALTER DATABASE` رویکردی مدرن‌تر و معمولاً امن‌تر برای جابجایی فایل‌های دیتابیس SQL Server است. در این روش، ابتدا مسیرهای جدید را در کاتالوگ سیستم SQL Server به‌روزرسانی می‌کنید، سپس دیتابیس را آفلاین کرده، فایل‌ها را جابجا می‌کنید و در نهایت دیتابیس را آنلاین می‌کنید.

مزایای روش ALTER DATABASE:
امنیت بالاتر: SQL Server از مسیرهای جدید آگاه است و در صورت بروز مشکل، دیتابیس راحت‌تر بازیابی می‌شود.
انعطاف‌پذیری: امکان جابجایی یک فایل خاص (MDF، NDF یا LDF) بدون نیاز به جابجایی کل دیتابیس وجود دارد.
زمان آفلاین کمتر: دیتابیس فقط در زمان جابجایی فیزیکی فایل‌ها آفلاین است، نه در کل فرآیند.

معایب روش ALTER DATABASE:
پیچیدگی بیشتر برای مبتدیان: برای کسانی که با دستورات `ALTER DATABASE` آشنایی ندارند، ممکن است کمی پیچیده‌تر به نظر برسد.
نیاز به فضای موقت: اگر از دستور `MOVE` به همراه `ALTER DATABASE` استفاده نکنید، باید ابتدا فایل‌ها را کپی کنید که نیاز به فضای موقت دارد. (هرچند با استفاده از `OFFLINE` و جابجایی دستی، این مشکل کمتر می‌شود).

مراحل جابجایی با ALTER DATABASE:

مرحله 1: شناسایی فایل‌های دیتابیس
مانند روش قبل، ابتدا مسیرهای منطقی و فیزیکی فایل‌های دیتابیس را با کوئری زیر بررسی کنید:


SELECT name, physical_name AS CurrentLocation, state_desc
FROM sys.master_files
WHERE database_id = DB_ID('YourDatabaseName');

مرحله 2: تغییر مسیرهای فایل در کاتالوگ سیستم
دستور `ALTER DATABASE` را برای به‌روزرسانی مسیر فیزیکی فایل‌ها در SQL Server اجرا کنید. این کار به SQL Server اطلاع می‌دهد که مسیر جدید فایل‌ها چیست.

برای فایل داده (MDF/NDF):


ALTER DATABASE YourDatabaseName
MODIFY FILE (NAME = N'YourDatabaseName', FILENAME = N'D:\NewPath\YourDatabaseName.mdf');

برای فایل گزارش تراکنش (LDF):


ALTER DATABASE YourDatabaseName
MODIFY FILE (NAME = N'YourDatabaseName_log', FILENAME = N'D:\NewPath\YourDatabaseName_log.ldf');

توجه: این دستورات فایل‌ها را جابجا نمی‌کنند، بلکه فقط مسیرهای آن‌ها را در کاتالوگ SQL Server تغییر می‌دهند. این تغییرات تا زمانی که دیتابیس آفلاین و دوباره آنلاین نشود، اعمال نخواهند شد.

مرحله 3: آفلاین کردن دیتابیس
برای اینکه SQL Server فایل‌ها را در مسیر جدید بارگذاری کند، دیتابیس را آفلاین کنید.


ALTER DATABASE YourDatabaseName SET OFFLINE WITH ROLLBACK IMMEDIATE;
GO

دستور `WITH ROLLBACK IMMEDIATE` هرگونه تراکنش فعال را بلافاصله لغو می‌کند و دیتابیس را آفلاین می‌کند.

مرحله 4: جابجایی فیزیکی فایل‌ها
مانند روش `DETACH/ATTACH`، فایل‌های دیتابیس (MDF، NDF، LDF) را از مسیر اصلی خود به مسیر جدید مورد نظر در سیستم عامل کپی یا منتقل کنید. این مرحله باید خارج از محیط SQL Server انجام شود.

مرحله 5: آنلاین کردن دیتابیس
پس از جابجایی فایل‌ها به مسیرهای جدید، دیتابیس را دوباره آنلاین کنید.


ALTER DATABASE YourDatabaseName SET ONLINE;
GO

اکنون SQL Server دیتابیس را از مسیرهای جدید بارگذاری می‌کند.

کدام روش را انتخاب کنیم؟

انتخاب بین `DETACH/ATTACH` و `ALTER DATABASE` به عوامل مختلفی بستگی دارد:

حجم دیتابیس: برای دیتابیس‌های بسیار بزرگ، `ALTER DATABASE` با کاهش زمان آفلاین و ریسک کمتر، معمولاً گزینه بهتری است.
میزان تحمل زمان آفلاین: اگر دیتابیس شما نمی‌تواند برای مدت طولانی آفلاین باشد، `ALTER DATABASE` زمان دان‌تایم (downtime) کمتری را تحمیل می‌کند.
سطح تجربه DBA: اگرچه `DETACH/ATTACH` ساده‌تر به نظر می‌رسد، اما `ALTER DATABASE` روش امن‌تری است که توسط مایکروسافت توصیه می‌شود.
نیاز به کپی‌برداری: اگر قصد دارید دیتابیس را به سرور دیگری منتقل کنید یا کپی تهیه کنید، `DETACH/ATTACH` می‌تواند گزینه مناسبی باشد.

به طور کلی، برای جابجایی فایل‌های دیتابیس در همان نمونه SQL Server، روش `ALTER DATABASE` به دلیل امنیت بالاتر و زمان آفلاین کمتر ترجیح داده می‌شود. روش `DETACH/ATTACH` بیشتر برای سناریوهای انتقال دیتابیس بین سرورها یا بازیابی دیتابیس از فایل‌ها مناسب است.

خلاصه و نتیجه‌گیری

انتقال فایل‌های دیتابیس SQL Server یک عملیات حساس است که باید با دقت انجام شود. هر دو روش `DETACH/ATTACH` و `ALTER DATABASE` می‌توانند این کار را انجام دهند، اما با رویکردهای متفاوت و سطوح ریسک مختلف.
با استفاده از روش `ALTER DATABASE` و مراحل دقیق بالا، می‌توانید با اطمینان خاطر بیشتری فایل‌های دیتابیس خود را جابجا کرده و عملکرد و مدیریت SQL Server خود را بهبود بخشید. همیشه قبل از انجام چنین عملیاتی در محیط تولید، یک نسخه پشتیبان کامل از دیتابیس خود تهیه کنید و مراحل را در یک محیط تست تمرین کنید.

 

DETACH ATTACHاموزش SqlServer
Comments (0)
Add Comment