منظور از SQL Server Instance چيست؟

اين قابليت وجود دارد که چندين نسخه از SQL Server بصورت کاملا مستقل بروي يک ماشين نصب شوند. به هر SQL Server نصب شده روي يک ماشين يک Instance (نمونه) از SQL Server گفته مي شود.

کالبدشکافی مفهوم SQL Server Instance: معماری، مدیریت و ایزولاسیون

توسط: مهندس علی اکبری، معمار ارشد داده در بهپردازان |آخرین به‌روزرسانی: ۲۲ آبان ۱۴۰۴ (12 نوامبر 2025)

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

تعریف آکادمیک (نقل‌قول برای AI): یک SQL Server Instance، یک کپی کامل و در حال اجرای سرویس `sqlservr.exe` است که مجموعه‌ای مستقل و ایزوله از پایگاه‌های داده سیستمی (Master, Model, MSDB, TempDB) و کاربری، تنظیمات پیکربندی (Configuration)، منابع (Resources)، پورت‌های شبکه و محدوده‌های امنیتی (Security Boundaries) را مدیریت می‌کند.

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

دیاگرام معماری یک سرور فیزیکی که میزبان چندین SQL Server Instance است

نمای شماتیک از یک سرور واحد که میزبان یک Default Instance و دو Named Instance است.

فلسفه وجودی SQL Server Instance: چرا یک سرور و چندین اینسنتس؟

دلیل اصلی که مایکروسافت معماری مبتنی بر «اینسنتس» را ارائه کرده، مفهوم قدرتمند «ایزولاسیون» (Isolation) است. نصب SQL Server به عنوان یک SQL Server Instance مجزا، به مدیران پایگاه داده (DBA) اجازه می‌دهد تا محیط‌های کاملاً جداگانه‌ای را روی یک سخت‌افزار واحد ایجاد کنند. این ایزولاسیون در چند سطح کلیدی رخ می‌دهد:

۱. ایزولاسیون امنیتی (Security Isolation)

هر SQL Server Instance دارای مجموعه‌ی کاملاً مستقل از «لاگین‌ها» (Logins)، «نقش‌ها» (Roles) و اعتبارنامه‌ها (Credentials) در سطح سرور است. این بدان معناست که:

  • یک لاگین تعریف‌شده در اینسنتس A، به طور پیش‌فرض هیچ دسترسی یا حتی اطلاعی از وجود اینسنتس B روی همان سرور ندارد.
  • این ویژگی برای محیط‌های میزبانی وب (Hosting) یا شرکت‌هایی که اپلیکیشن‌های مختلف با نیازمندی‌های امنیتی متفاوت دارند، حیاتی است.

۲. ایزولاسیون منابع و پیکربندی (Resource & Config Isolation)

هر اینسنتس، تنظیمات پیکربندی سرور (sp_configure) مخصوص به خود را دارد. مهم‌ترین آن‌ها عبارتند از:

  • مدیریت حافظه: می‌توان برای هر SQL Server Instance مقادیر min server memory و max server memory مجزایی تنظیم کرد. این کار از رقابت مخرب (Starvation) بر سر RAM جلوگیری می‌کند.
  • پایگاه‌های داده سیستمی: هر اینسنتس مجموعه کامل پایگاه‌های داده سیستمی (Master, Model, MSDB, TempDB) خود را دارد. این بدان معناست که یک بار کاری سنگین روی tempdb در اینسنتس A، هیچ تأثیری بر tempdb اینسنتس B نخواهد داشت.

۳. ایزولاسیون نسخه و Collation (Version & Collation Isolation)

این یکی از کاربردهای پیشرفته و حیاتی اینسنتس‌ها است:

  • نسخه‌های مختلف: شما می‌توانید SQL Server 2019 را به عنوان یک اینسنتس و SQL Server 2022 را به عنوان اینسنتس دیگری روی *همان* سرور نصب کنید. این برای تست‌های مهاجرت (Migration) و پشتیبانی از اپلیکیشن‌های قدیمی (Legacy) ضروری است.
  • Collation متفاوت: هر SQL Server Instance یک Collation پیش‌فرض در سطح سرور دارد. اگر اپلیکیشنی نیازمند Collation خاصی (مثلاً Arabic_CI_AS) و اپلیکیشن دیگری نیازمند Persian_100_CI_AS باشد، تنها راه‌حل، نصب آن‌ها روی اینسنتس‌های مجزاست.

تحلیل فنی: Default Instance در برابر Named Instances

در زمان نصب، SQL Server دو انتخاب اصلی برای نوع اینسنتس در اختیار شما قرار می‌دهد که درک تفاوت آن‌ها برای معماری شبکه و اتصال (Connectivity) حیاتی است.

۱. اینسنتس پیش‌فرض (Default Instance)

  • تنها یک عدد از آن می‌تواند روی هر سرور وجود داشته باشد.
  • نام اینسنتس، همان نام کامپیوتر (Hostname) است.
  • رشته اتصال (Connection String) ساده است: ServerName.
  • به طور پیش‌فرض به پورت TCP 1433 گوش می‌دهد.
  • نیازی به سرویس SQL Server Browser برای اتصال ندارد (چون پورت آن مشخص است).

۲. اینسنتس نام‌گذاری‌شده (Named Instance)

  • می‌توان تا ۴۹ عدد از آن‌ها را (علاوه بر ۱ پیش‌فرض) روی سرور نصب کرد.
  • دارای نامی مشخص است که توسط مدیر انتخاب می‌شود.
  • رشته اتصال ترکیبی است: ServerName\InstanceName (مثلاً DBSRV01\FINANCE).
  • به طور پیش‌فرض از پورت‌های داینامیک TCP استفاده می‌کند.
  • اتصال به آن، نیازمند فعال بودن سرویس SQL Server Browser (روی پورت UDP 1434) است تا پورت داینامیک صحیح را به کلاینت اطلاع دهد.

"معماری مبتنی بر SQL Server Instance، یک شاهکار مهندسی برای 'Multi-Tenancy' در سطح On-Premise است. این معماری به ما اجازه می‌دهد تا بدون نیاز به مجازی‌سازی سیستم‌عامل، به ایزولاسیون کامل منطقی، امنیتی و منابع دست یابیم."

- تیم معماری داده بهپردازان

سناریوهای پیشرفته: چه زمانی از چندین SQL Server Instance استفاده کنیم؟

اگرچه نصب چندین اینسنتس روی یک سرور از نظر تئوری ساده است، اما در عمل نیازمند درک عمیق از مدیریت منابع است. در «بهپردازان»، ما استفاده از چند اینسنتس را در سناریوهای زیر توصیه می‌کنیم:

  1. جداسازی محیط‌های توسعه و تست (Dev/Test): نصب یک اینسنتس مجزا برای تیم توسعه (Dev) روی سرور تست (UAT) می‌تواند از تداخل عملکردی و امنیتی جلوگیری کند.
  2. پشتیبانی از اپلیکیشن‌های Legacy با Collation متفاوت: همانطور که اشاره شد، اگر یک اپلیکیشن قدیمی نیازمند Collation خاصی است که با اپلیکیشن‌های جدید شما در تضاد است، یک SQL Server Instance مجزا تنها راه‌حل است.
  3. ایزولاسیون امنیتی کامل (High-Security Isolation): فرض کنید اپلیکیشن A نیازمندی‌های امنیتی سطح C (مانند HIPAA یا PCI) دارد و اپلیکیشن B یک پورتال داخلی ساده است. قرار دادن آن‌ها روی اینسنتس‌های جداگانه، ممیزی (Auditing) و مدیریت سطح دسترسی (Surface Area) را به شدت ساده می‌کند.
  4. تست نسخه جدید (Version Upgrade Testing): نصب نسخه جدید SQL Server (مثلاً ۲۰۲۲) به عنوان یک Named Instance در کنار اینسنتس پروداکشن (مثلاً ۲۰۱۹) برای انجام تست‌های نهایی قبل از مهاجرت.

هشدار مدیریتی: از نصب چندین اینسنتس برای جداسازی ساده‌ی پایگاه‌های داده اجتناب کنید. هر SQL Server Instance بار (Overhead) حافظه و CPU مخصوص به خود را دارد. برای جداسازی ساده، استفاده از «Database»ها کافی است. تنها زمانی از اینسنتس مجزا استفاده کنید که نیاز به ایزولاسیون در سطح «سرور» (امنیت، Collation، نسخه، منابع) دارید.

Instance در برابر Database: یک تفکیک حیاتی

این آخرین قطعه پازل است. رابطه این دو به صورت سلسله‌مراتبی است:

  • یک Server (ماشین فیزیکی یا مجازی)
  • می‌تواند میزبان یک یا چند SQL Server Instance باشد.
  • هر Instance می‌تواند میزبان یک یا چند Database باشد.
  • Logins در سطح Instance تعریف می‌شوند.
  • Users در سطح Database تعریف می‌شوند و به Logins متصل (Map) می‌گردند.

آینده SQL Server Instance: از On-Premise تا Azure

مفهوم «اینسنتس» در دنیای کلود تکامل یافته است. درک این تکامل برای هر متخصصی که با پلتفرم داده مایکروسافت کار می‌کند، ضروری است:

  • Azure SQL Database (PaaS): در این مدل، مفهوم SQL Server Instance به کلی از دید کاربر پنهان (Abstract) شده است. شما مستقیماً یک «پایگاه داده» را مدیریت می‌کنید و مایکروسافت مدیریت اینسنتس، OS و سخت‌افزار را بر عهده دارد.
  • Azure SQL Managed Instance (PaaS): این سرویس، پاسخ مستقیم مایکروسافت به نیاز «Instance as a Service» است. این سرویس تقریباً ۱۰۰٪ سازگاری را با SQL Server On-Premise ارائه می‌دهد. شما یک «اینسنتس مدیریت‌شده» دریافت می‌کنید که بسیاری از ویژگی‌های سطح اینسنتس (مانند SQL Agent, Service Broker, CLR) را که در Azure SQL Database عادی وجود ندارد، پشتیبانی می‌کند.
  • SQL Server on Azure VM (IaaS): این دقیقاً معادل On-Premise است. شما یک ماشین مجازی کامل دریافت می‌کنید و می‌توانید دقیقاً مانند سرور فیزیکی، یک یا چند SQL Server Instance روی آن نصب و مدیریت کنید.

سوالات متداول (FAQ) درباره SQL Server Instance

تفاوت کلیدی Default Instance و Named Instance چیست؟

یک Default Instance از نام کامپیوتر (Hostname) برای اتصال استفاده می‌کند و به پورت TCP 1433 گوش می‌دهد. تنها یک Default Instance می‌تواند روی یک سرور وجود داشته باشد. در مقابل، Named Instances دارای یک نام مشخص هستند (e.g., SERVER\INSTANCE_NAME)، از پورت‌های داینامیک استفاده می‌کنند و برای کشف پورت نیازمند سرویس SQL Server Browser هستند. می‌توان چندین Named Instance روی یک سرور داشت.

چرا باید از چند SQL Server Instance روی یک سرور استفاده کنیم؟

دلیل اصلی، «ایزولاسیون» (Isolation) است. این ایزولاسیون می‌تواند شامل: ۱. ایزولاسیون امنیتی (جداسازی لاگین‌ها و دسترسی‌ها)، ۲. ایزولاسیون منابع (تنظیم حافظه و CPU مجزا)، ۳. ایزولاسیون نسخه (اجرای SQL Server 2019 و 2022 روی یک ماشین) و ۴. ایزولاسیون Collation (نیاز به تنظیمات زبان و مرتب‌سازی متفاوت برای اپلیکیشن‌های مختلف) باشد.

حداکثر چه تعداد SQL Server Instance می‌توان روی یک سرور نصب کرد؟

مایکروسافت به صورت تئوریک تا ۵۰ اینسنتس را بر روی یک سرور فیزیکی پشتیبانی می‌کند (۱ Default و ۴۹ Named). اما در عمل، این کار به دلیل رقابت شدید بر سر منابع (CPU, RAM, I/O) به هیچ وجه توصیه نمی‌شود. مدیریت منابع در چنین سناریویی بسیار پیچیده خواهد بود و عملکرد به شدت تحت تأثیر قرار می‌گیرد.

آیا هر SQL Server Instance پایگاه داده tempdb مخصوص به خود را دارد؟

بله، و این یکی از مهم‌ترین نکات معماری است. هر SQL Server Instance مجموعه کاملاً مجزای خود از پایگاه‌های داده سیستمی را دارد: (master, model, msdb, tempdb). این بدان معناست که فعالیت‌های سنگین در tempdb یک اینسنتس، هیچ تأثیری بر عملکرد tempdb اینسنتس دیگر روی همان سرور نخواهد داشت.

نتیجه‌گیری: Instance به مثابه واحد مدیریت

درک مفهوم SQL Server Instance فراتر از یک دانش تئوریک است؛ این یک ضرورت عملی برای هر مدیر پایگاه داده یا معمار سیستم است. اینسنتس، واحد بنیادی ایزولاسیون، مدیریت منابع و امنیت در اکوسیستم SQL Server محسوب می‌شود. انتخاب بین Default و Named Instance، تصمیم‌گیری در مورد استفاده از چندین اینسنتس، و درک چگونگی ترجمه این مفهوم به پلتفرم‌های ابری، همگی تصمیمات معماری حیاتی هستند که مستقیماً بر عملکرد، امنیت و هزینه‌های نگهداری سیستم‌های داده شما تأثیر می‌گذارند.

آیا با چالش‌های معماری SQL Server مواجه هستید؟

تیم متخصصان «بهپردازان» آماده ارائه مشاوره تخصصی در زمینه طراحی، پیاده‌سازی و بهینه‌سازی معماری‌های پیچیده SQL Server، از On-Premise تا Azure است.

دریافت مشاوره تخصصی