ارتقا به SQL Server 2022: راهنمای مهاجرت آسان

راهنمای جامع ارتقا به SQL Server 2022: مهاجرت بدون دردسر

ارتقا به SQL Server 2022 یک گام مهم برای بهبود عملکرد، امنیت و قابلیت‌های پایگاه داده شماست. روش ارتقا کنار به کنار (Side-by-Side Upgrade) بهترین گزینه برای مهاجرت به SQL Server 2022 است که حداقل زمان توقف (Downtime) و ریسک را به همراه دارد. این روش شامل نصب یک نمونه جدید از SQL Server 2022 در کنار نمونه فعلی شما و سپس انتقال پایگاه‌های داده و اشیاء سرور به محیط جدید است. در این مقاله به بررسی دقیق مراحل ارتقا کنار به کنار به SQL Server 2022 می‌پردازیم.

چرا ارتقا کنار به کنار به SQL Server 2022؟

انتخاب روش ارتقا کنار به کنار به SQL Server 2022 مزایای متعددی دارد:

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

برنامه‌ریزی پیش از ارتقا به SQL Server 2022

برنامه‌ریزی دقیق، کلید موفقیت هر ارتقا SQL Server است. مراحل زیر را با دقت دنبال کنید:

  • بررسی سازگاری: اطمینان حاصل کنید که برنامه‌های کاربردی و سیستم‌عامل شما با SQL Server 2022 سازگار هستند. از ابزار Data Migration Assistant (DMA) برای ارزیابی سازگاری پایگاه‌های داده استفاده کنید.
  • پشتیبان‌گیری کامل: یک پشتیبان‌گیری کامل از تمام پایگاه‌های داده، گزارش‌های تراکنش، و اشیاء سطح سرور (مانند لاگین‌ها و جاب‌ها) از نمونه فعلی SQL Server خود تهیه کنید.
  • مستندسازی تنظیمات: تمامی تنظیمات مهم سرور از جمله پیکربندی حافظه، CPU، تنظیمات Trace Flags، Collation سرور، و تنظیمات شبکه را مستند کنید.
  • منابع سخت‌افزاری: مطمئن شوید که سرور جدید دارای منابع سخت‌افزاری کافی (CPU، RAM، Disk I/O) برای پشتیبانی از SQL Server 2022 و حجم کاری شماست.
  • برنامه‌ریزی زمان توقف: یک پنجره زمانی مشخص برای توقف سرویس برنامه‌های کاربردی و مهاجرت نهایی انتخاب کنید.

نصب SQL Server 2022 جدید

یک نمونه جدید از SQL Server 2022 را در یک سرور جدید یا همان سرور فعلی (به عنوان یک نمونه نام‌گذاری شده) نصب کنید. اطمینان حاصل کنید که تنظیمات زیر را به درستی اعمال می‌کنید:

  • انتخاب ویژگی‌های مناسب (Database Engine، SSIS، SSRS و غیره).
  • پیکربندی حساب‌های سرویس (Service Accounts) با حداقل دسترسی لازم.
  • تنظیم Collation سرور به گونه‌ای که با نمونه قدیمی سازگار باشد، مگر اینکه عمداً قصد تغییر آن را داشته باشید. می‌توانید Collation فعلی را با استفاده از دستور زیر بررسی کنید:
SELECT @@SERVERNAME AS ServerName, SERVERPROPERTY('Collation') AS ServerCollation;

این دستور نام سرور و Collation فعلی آن را نمایش می‌دهد که برای اطمینان از سازگاری در سرور جدید بسیار مهم است.

مهاجرت پایگاه داده‌ها به SQL Server 2022

روش‌های مختلفی برای مهاجرت پایگاه‌های داده به SQL Server 2022 وجود دارد:

    • پشتیبان‌گیری و بازیابی (Backup and Restore): این رایج‌ترین و مطمئن‌ترین روش است.

ابتدا از پایگاه داده در نمونه قدیمی پشتیبان تهیه کنید:

BACKUP DATABASE [YourDatabaseName] TO DISK = N'C:\Backup\YourDatabaseName.bak' WITH NOFORMAT, NOINIT, NAME = N'Full Backup of YourDatabaseName', SKIP, NOREWIND, NOUNLOAD, STATS = 10;

سپس فایل پشتیبان را به سرور SQL Server 2022 جدید منتقل کرده و بازیابی کنید:

RESTORE DATABASE [YourDatabaseName] FROM DISK = N'C:\Backup\YourDatabaseName.bak' WITH FILE = 1, MOVE N'YourDatabaseName_Data' TO N'E:\SQLData\YourDatabaseName.mdf', MOVE N'YourDatabaseName_Log' TO N'F:\SQLLog\YourDatabaseName_log.ldf', NOUNLOAD, STATS = 5;

مطمئن شوید که مسیرهای فایل داده (MDF) و فایل لاگ (LDF) را با مسیرهای مناسب در سرور SQL Server 2022 جدید خود جایگزین کرده‌اید.

  • جدا کردن و پیوستن (Detach and Attach): این روش برای پایگاه‌های داده کوچک‌تر مناسب است، اما زمان توقف بیشتری نیاز دارد.
  • Data Migration Assistant (DMA): این ابزار مایکروسافت می‌تواند به مهاجرت پایگاه‌های داده کمک کند و مشکلات سازگاری را شناسایی نماید.

پس از مهاجرت، Compatibility Level پایگاه داده را به SQL Server 2022 (یعنی 160) تغییر دهید تا از تمام قابلیت‌های جدید بهره‌مند شوید:

ALTER DATABASE [YourDatabaseName] SET COMPATIBILITY_LEVEL = 160;

مهاجرت اشیاء سطح سرور به SQL Server 2022

پایگاه‌های داده تنها بخشی از مهاجرت هستند. اشیاء سطح سرور نیز باید به نمونه SQL Server 2022 جدید منتقل شوند. این موارد شامل:

    • لاگین‌ها (Logins) و کاربران سرور: از اسکریپت‌های T-SQL یا ابزارهای Migration Wizard برای انتقال لاگین‌ها (هم لاگین‌های ویندوز و هم لاگین‌های SQL) به همراه SID (Security Identifier) آنها استفاده کنید تا کاربران پایگاه داده به درستی به لاگین‌ها نگاشت شوند.

برای استخراج لاگین‌ها، می‌توانید از این اسکریپت نمونه استفاده کنید:

SELECT
    'CREATE LOGIN [' + sp.name + '] ' +
    CASE
        WHEN sp.type IN ('U', 'G') THEN 'FROM WINDOWS WITH DEFAULT_DATABASE = [' + sp.default_database_name + '], DEFAULT_LANGUAGE = [' + sp.default_language_name + '];'
        WHEN sp.type = 'S' THEN 'WITH PASSWORD = ' + master.sys.fn_varbintohexstr(l.password_hash) + ' HASHED, SID = ' + master.sys.fn_varbintohexstr(sp.sid) + ', DEFAULT_DATABASE = [' + sp.default_database_name + '], DEFAULT_LANGUAGE = [' + sp.default_language_name + '], CHECK_EXPIRATION = ' + CASE WHEN l.is_expiration_checked = 1 THEN 'ON' ELSE 'OFF' END + ', CHECK_POLICY = ' + CASE WHEN l.is_policy_checked = 1 THEN 'ON' ELSE 'OFF' END + ';'
    END
FROM
    sys.server_principals sp
LEFT JOIN
    sys.sql_logins l ON sp.principal_id = l.principal_id
WHERE
    sp.type IN ('S', 'U', 'G')
    AND sp.name NOT LIKE '##%' AND sp.name NOT LIKE 'NT SERVICE\%' AND sp.name NOT LIKE 'NT AUTHORITY\%' AND sp.name NOT IN ('sa', 'public');

این اسکریپت دستورات `CREATE LOGIN` را برای اکثر لاگین‌های استاندارد SQL و ویندوز تولید می‌کند. آن را اجرا کرده، خروجی را کپی و در سرور جدید SQL Server 2022 اجرا کنید.

  • جاب‌ها (SQL Server Agent Jobs): تمام جاب‌های SQL Server Agent را به نمونه جدید منتقل کنید.
  • لینکد سرورها (Linked Servers): تمام لینکد سرورها و تنظیمات مربوط به آنها را بازسازی کنید.
  • اعلانات (Alerts) و اپراتورها (Operators): اعلان‌ها و اپراتورهای SQL Server Agent را پیکربندی کنید.
  • پیکربندی SSIS، SSRS و SSAS: اگر از این سرویس‌ها استفاده می‌کنید، بسته‌ها، گزارش‌ها و مکعب‌های مربوطه را نیز مهاجرت کنید.

مراحل پس از مهاجرت و تست در SQL Server 2022

پس از انتقال پایگاه‌های داده و اشیاء سرور، مراحل زیر را دنبال کنید:

    • به‌روزرسانی آمار (Update Statistics): پس از مهاجرت، به‌روزرسانی آمار برای بهبود عملکرد کوئری‌ها در SQL Server 2022 ضروری است.
EXEC sp_updatestats;
    • یکپارچگی پایگاه داده (Check DB Integrity): یک بررسی یکپارچگی کامل برای تمامی پایگاه‌های داده اجرا کنید.
DBCC CHECKDB ('YourDatabaseName') WITH NO_INFOMSGS;
  • تست برنامه‌های کاربردی: تمامی برنامه‌های کاربردی متصل به SQL Server را به طور کامل تست کنید تا از عملکرد صحیح آنها اطمینان حاصل شود. این شامل تست عملکردهای اصلی، گزارش‌گیری و تراکنش‌های پیچیده است.
  • بررسی عملکرد: عملکرد سیستم را با ابزارهایی مانند SQL Server Profiler یا Extended Events در SQL Server 2022 جدید مقایسه کنید.
  • تغییر رشته اتصال (Connection Strings): پس از اطمینان از صحت عملکرد، رشته‌های اتصال برنامه‌های کاربردی را به نمونه SQL Server 2022 جدید تغییر دهید.

نتیجه‌گیری ارتقا به SQL Server 2022

ارتقا به SQL Server 2022 یک فرآیند دقیق است که نیاز به برنامه‌ریزی و اجرای محتاطانه دارد. با پیروی از این مراحل، می‌توانید مهاجرت را با حداقل ریسک و زمان توقف انجام دهید و از مزایای جدیدترین نسخه SQL Server بهره‌مند شوید. این رویکرد تضمین می‌کند که زیرساخت پایگاه داده شما مدرن، کارآمد و امن باقی می‌ماند.

 

sql server
Comments (0)
Add Comment