در مقاله قبل انواع bottleneck ها در SQL Server معرفی شد. bottleneck ها به طور کلی میتوانند در مواردی مانند: 1- حافظه، 2- پردازنده، 3- دیسک و 4- اتصالات کاربران رخ دهند. همچنین اشاره شد که هر یک از این bottleneck ها میتواند منجر به کاهش کارایی سرور شود. لذا لازم است عوامل مختلفی که منجر به بروز آنها میشوند را شناسایی و رفع نمود. برای شناسایی bottleneck ها لازم است تا به نشانههای آنها در سیستم توجه نمود. به این منظور مانیتورینگ میتواند ابزاری برای تحت نظر قرار دادن این نشانهها در سیستم باشد. به کمک مانیتورینگ و تعریف شاخصهای مختلف که هر کدام یکی از ابعاد bottleneck ها را پوشش میدهند، میتوان نظارتی بر عملکرد کلی سیستم داشت.
همچنین در ضرورت مانیتورینگ SQL Server لازم است اشاره شود که با توجه به اینکه SQL Server به عنوان یک سیستم مدیریت پایگاه داده رابطهای بسیار پرکاربرد و محبوب میباشد، نظارت بر نحوه عملکرد آن اهمیت بسیار زیادی دارد. یکی از مواردی که باید به آن توجه نمود این است که SQL Server ممکن است در ابتدا یک سیستم ساده به نظر آید که با استفاده از آن میتوان پایگاه داده ایجاد کرد. عملیات مرتبط با پایگاه داده مانند ایجاد، خواندن، نوشتن داده و ... را انجام داد. اما به مرور با افزایش حجم داده و استفاده بیشتر از این سیستم متوجه خواهید شد که همه چیز به سادگی که به نظر میرسد نیست و این سیستم دارای عملکردهای پیچیدهای مانند مدیریت حافظه، بافر، زمانبندی، مدیریت مصرف پردازنده و ... میباشد. که پیچیدگیهای زیادی در بخشهای مختلف آن وجود دارد. ضعف عملکرد و بروز مشکل در هر یک از بخشهای معماری معرفی شده میتواند منجر به کند شدن و پایین آمدن کارایی کل سیستم شود. لذا ضرورت وجود راهکارهایی به منظور مانیتورینگ و نظارت بر عملکرد بخشهای مختلف SQL Server بسیار ضروری است. در این مقاله به بررسی شاخصهای مختلف مرتبط با حافظه خواهیم پرداخت.
به صورت پیشفرض حافظه در SQL Server به صورت پویا (در زمان اجرا) و براساس منابع موجود سیستم تخصیص داده میشود. اگر که SQL Server نیاز به حافظه بیشتری داشته باشد، از سیستم عامل درخواست میکند که آیا حافظه آزاد برای تخصیص به آن وجود دارد یا خیر. میزان حداقل و حداکثر حافظه (min server memory و max server memory) را میتوان به صورت دستی در SQL Server تنظیم نمود. به منظور مانیتورینگ میزان حافظهای که SQL Server استفاده مینماید از شاخصهای زیر استفاده میشود:
این شاخص میزان حافظه را که SQL Server memory manager از حافظه سیستم عامل به SQL Server تخصیص داده است مشخص مینماید. انتظار میرود که این میزان حافظه تخصیص داده شده به SQL Server با شروع به کار آن و به مرور با افزایش تعداد و حجم کوئریها به پایگاه داده افزایش یابد. به منظور به دست آوردن مقدار این شاخص میتوان به فایل sys.dm_os_sys_info کوئری زد و ستون commited_kb را خواند.
این شاخص میان حافظه ایدهآل که SQL Server میتواند براساس بار کاری جاری سرور استفاده کند را مشخص مینماید. بعد از این که مدت زمانی از اجرای SQL Server گذشت، برای اینکه بررسی شود آیا میزان حافظه مورد نیاز دریافت شده است یا نه، مقدار این شاخص با Total Server Memory مقایسه میشود. بعد از گذشت مدت زمانی از شروع به کار SQL Server، مقدار Total Server Memory و Target Server Memory یکسان میشود. در صورتی که مقدار Total Server Memory به طور محسوسی کمتر از Target Server Memory باشد، ممکن است SQL Server دچار کمبود حافظه وMemory pressure شده باشد یا اینکه مقدار Max Server Memory بسیار پایین تنظیم شده است. البته در زمان شروع به کار SQL Server و تا مدت زمانی پس از شروع به کار، مقدار Total Server Memory کمتر از Target Server Memory خواهد بود و این مسئله طبیعی است.
بنابراین با فرض این که مدتی از شروع به کار SQL Server گذشته باشد و حافظه هم به میزان لازم تخصیص داده شده باشد، لازم است رابطه زیر برقرار باشد:
· Total Server Memory = Target Server Memory (Normal)
· Total Server Memory << Target Server Memory (Possibility of memory pressure)
این شاخص مشخص میکند چه درصدی از درخواستهای صفحات حافظه در بافر موجود بوده است و از بافر خوانده شده است. صفحات حافظهای که در بافر موجود نباشند لازم است از دیسک خوانده شوند که سرعت پایینتری هم نسبت به بافر دارد. در حالت ایدهآل باید دادهها به نحوی در حافظه بافر ذخیره شوند که SQL Server تمام صفحات حافظه مورد نظر را از بافر بخواند و نیازی به دسترسی به دیسک نباشد. در این حالت مقدار شاخص Buffer Cache Hit Ratio مقدار 100 درصد خواهد بود. مقدار پیشنهادی برای این شاخص مقداری بالاتر از 90 درصد است.
دومین شاخص که مرتبط با حافظه بافر است شاخص Page Life Expectancy است که بالاتر نیز توضیح داده شده است. این شاخص مدت زمان مورد انتظار برای ماندن یک صفحه حافظه در بافر را نشان میدهد. به طور کلی اگر صفحات حافظه مدت زمان بیشتری در بافر بمانند احتمال یافتن آنها در زمان نیاز توسط سرور بیشتر است. اگر در زمان نیاز صفحات در حافظه بافر نباشند لازم است از دیسک خوانده شوند که سربار خواهد داشت. همچنین اگر حافظه SQL Server که به بافر تخصیص داده شده است کافی نباشد، صفحات به طور مداوم بین حافظه دیسک و بافر جابهجا میشوند که طول عمر آنها را در حافظه بافر کاهش خواهد داد. لذا در این حالت لازم است تخصیص حافظه بیشتر برای SQL Server را بررسی نمود. مقدار پیشنهادی برای این شاخص همانطور که پیشتر نیز ذکر شد حدود 300 ثانیه یا 5 دقیقه است.
زمانی که مقدار Total Server Memory از مقدار Target Server Memory کمتر است میتواند نشانهای از کمبود حافظه و اصطلاحا Memory Pressure باشد. اما لازم است به شاخصهای دیگری نیز در این راستا توجه نمود. در صورتی که مقادیر شاخصهای مرتبط نیز کمبود حافظه را تایید نماید میتوان با اطمینان بیشتری در مورد کم بودن حافظه تخصیص داده شده به SQL Server اظهار نظر نمود. در ادامه این شاخصها را بررسی خواهیم نمود.
این شاخص که پیشتر نیز بررسی شد، مدت زمانی است که یک صفحه داده در حافظه بافر قرار دارد. این شاخص یکی از مواردی است که memory pressure را نشان میدهد. به این صورت که زمانی که میزان حافظه SQL Server کم است، SQL Server مجبور است فضای حافظه را با صفحاتی که جدیدتر مورد نیاز هستند پر نماید لذا صفحات قبلی را از حافظه پاک مینماید و طول عمر این صفحات در حافظه کمتر از حدی خواهد بود. حدآستانه برای این شاخص مقدار 300 ثانیه برای هر 4 گیگابایت حافظه رم بر روی SQL Server میباشد. به این معنی که اگر کل حافظه 4 گیگابایت باشد، هر صفحه داده در حافظه باید برای مدت حداقل 5 دقیقه در حافظه نگهداری شود.
Lazy Writer یک فرایند سیستمی است که صفحاتی که مدت زیادی است مورد استفاده نبودهاند از حافظه بافر حذف مینماید تا فضای حافظه برای استفادههای دیگر آزاد باشد. این شاخص مشخص کننده تعداد دفعاتی است که SQL Server، dirty page هایی که (صفحاتی که خوانده شدهاند و/یا تغییراتی در آنها داده شده است) برای مدتی استفاده نشده اند را از حافظه بافر به دیسک منتقل مینماید. در صورتی که این مقدار نزدیک به صفر باشد به این معنی است که احتمالا حافظه به مقدار مورد نیاز وجود داشته است و نیازی به جابهجایی dirty page ها نبوده است.
این شاخص تعداد کل SQL Server Process هایی را نشان میدهد که منتظر تخصیص فضای حافظه هستند. در حالت ایدهآل مقدار این شاخص باید صفر باشد. وجود حتی یک Process که منتظر حافظه است میتواند نشاندهنده کمبود فضای حافظه باشد. بنابراین این شاخص نیز در کنار سایر شاخصها میتواند به منظور بررسی کافی بودن میزان حافظه تخصیص داده شده به SQL Server استفاده شود.
در SQL Server همانند تمامی سیستمهای مدیریت پایگاه داده دیگر لازم است دو فرایند Logging و Recovery به طور مداوم انجام شود. تمامی عملیات در SQL Server به صورت لاگهایی در فایلهای مخصوص به نام transaction log ثبت و نگهداری میشوند. هر تغییری در پایگاه دادهها لازم است به نوعی ذخیره شود. این لاگها به نوعی ذخیره میشوند تا در صورت بروز مشکلی در پایگاه داده یا در دادهها بتوان تغییرات را معکوس کرد یا دوباره تکرار نمود. فایلهای transaction log ظرفیتهای مشخصی دارند (با مقدار ‘Log File(s) Size (KB)’ مشخص میشود) که به مرور با ثبت تغییرات در فرمت لاگ در آنها، ظرفیت فایل پر خواهد شد (میزان استفاده شده فایل لاگ با مقدار ‘Log File(s) Used Size (KB)’ مشخص میشود). برای اینکه بتوان میزان فضای استفاده شده لاگها را مانیتور نمود شاخص ‘Percent Log Used’ معرفی میشود که در ادامه بررسی خواهد شد.
این شاخص مشخص میکند هر پایگاه داده چه درصدی از فضای لاگ را استفاده کرده است (میزان فضای استفاده شده در لاگ). به منظور دسترسی به این شاخص میتوان به فایل sys.dm_os_performance_counters کوئری زد و ستون Percent Log Used را خواند. زمانی که مقدار این شاخص از حد آستانه گذر کند نشاندهنده این است که سرور فضای کافی برای ذخیره لاگها ندارد و لازم است فضای بیشتری به فایل لاگها اختصاص داده شود یا اینکه از طریق Recovery از لاگها فضای فایل لاگ را خالی نمود. معمولا مقدار 80 درصد وضعیت هشدار و مقدار 90 درصد وضعیت بحرانی را برای این شاخص نشان میدهد و لازم است اقدام مناسب در این راستا صورت گیرد.
عملیات لاگ در SQL Server کمک میکند تا در مواقع بروز مشکل transaction هایی که نهایی بودهاند و اصطلاحا commit شدهاند به درستی در پایگاه داده بعد از بروز مشکل اعمال شوند و همچنین transaction های uncommitted که نباید در پایگاه داده اعمال شوند بعد از بروز مشکل نیز اثری بر روی پایگاه داده نداشته باشند. فرایند لاگ با عملیاتی به نام Recovery همراه است. Recovery به معنای تکرار یا معکوس نمودن تغییراتی است که در فایل transaction log به صورت رکوردهای لاگ ثبت شده است. تکرار رکوردهای لاگ به فاز REDO (Roll forward) و معکوس نمودن رکوردهای لاگ به فاز UNDO (Roll back) شناخته میشود.
در SQL Server سه مدل Recovery مختلف وجود دارد: 1- مدل FULL، 2- مدل SIMPLE و 3- مدل BULK_LOGGED. در مدل FULL تمامی اجزای یک عملیات به صورت لاگ باید ذخیره شود. در این مدل از Recovery تا زمانی که یک Log backup انجام نشود فایل لاگها فضای خالی آزاد نخواهد کرد. احتمال پرشدن سریعتر فضای فایل لاگ در این مدل از Recovery بسیار بیشتر است. در مدل BULK_LOGGED اجازه میدهد برخی از عملیات پایگاه داده به صورت کامل لاگ نشوند و اصطلاحا partially logged وجود دارد لذا در این حالت تعداد رکوردهای لاگی که ثبت میشود بسیار کمتر از حالت FULL میباشد و بنابراین احتمال transaction log growth یا افزایش سایز فایل لاگ را کاهش میدهد. مدل SIMPLE اما رفتار logging آن همانند مدل BULK_LOGGED است با این تفاوت که رفتار log backup آن متفاوت است به این صورت که تا زمانی که به Checkpoint نرسیم عملیات log backup انجام نمیشود. هر کدام از این روشها مزایا و معایبی دارد که توجه به آنها و استفاده درست با توجه به کاربرد سیستم میتواند بر روی میزان فضای آزاد و استفاده شده فایل لاگ تاثیر گذارد.