بهینه سازی عملکرد SQL Server مانیتورینگ IO با fn_virtualfilestats

بهینه‌سازی عملکرد SQL Server: مانیتورینگ جامع I/O با fn_virtualfilestats

برای هر متخصص پایگاه داده SQL Server، نظارت بر عملکرد سیستم و شناسایی گلوگاه‌ها از اهمیت بالایی برخوردار است. یکی از مهم‌ترین حوزه‌ها برای بررسی، عملکرد ورودی/خروجی (I/O) فایل‌های دیتابیس است. عملکرد کند I/O می‌تواند منجر به تاخیرهای قابل توجه در کوئری‌ها، کاهش توان عملیاتی و تجربه کاربری ضعیف شود. خوشبختانه، SQL Server ابزارهای قدرتمندی برای کمک به این نظارت ارائه می‌دهد که یکی از آن‌ها تابع جدول‌دار `fn_virtualfilestats` است.

`fn_virtualfilestats` یک تابع جدول‌دار سیستمی (System Table-Valued Function) است که اطلاعات مربوط به آمار I/O فایل‌های داده و لاگ را برای پایگاه‌های داده SQL Server ارائه می‌دهد. این تابع به شما اجازه می‌دهد تا ببینید یک فایل دیتابیس خاص چقدر عملیات خواندن و نوشتن را انجام داده است، حجم داده‌های خوانده و نوشته شده چقدر بوده و مهم‌تر از آن، چه مقدار زمان برای این عملیات I/O صرف شده است. این اطلاعات حیاتی برای شناسایی فایل‌هایی است که بیشترین بار I/O را دارند یا دچار تاخیرهای طولانی I/O می‌شوند.

این تابع دو پارامتر می‌پذیرد: `DatabaseID` و `FileID`. اگر می‌خواهید آمار I/O را برای یک پایگاه داده خاص و تمام فایل‌های آن ببینید، می‌توانید `DatabaseID` آن دیتابیس را ارسال کرده و برای `FileID` مقدار `NULL` را قرار دهید. برای مشاهده آمار تمام پایگاه‌های داده روی سرور، می‌توانید برای هر دو پارامتر `NULL` ارسال کنید.


SELECT * FROM sys.fn_virtualfilestats(DB_ID('AdventureWorks2019'), NULL);

در مثال بالا، `DB_ID(‘AdventureWorks2019’)` شناسه دیتابیس ‘AdventureWorks2019’ را برمی‌گرداند. این کوئری تمام آمار I/O را برای تمامی فایل‌های مربوط به این پایگاه داده خاص نمایش می‌دهد. اگر می‌خواهید آمار را برای یک فایل خاص در آن دیتابیس مشاهده کنید، `FileID` آن فایل را به جای `NULL` قرار می‌دهید.

ستون‌های خروجی این تابع شامل موارد زیر هستند که هر کدام بینشی کلیدی در مورد عملکرد I/O ارائه می‌دهند:

* `database_id`: شناسه پایگاه داده.
* `file_id`: شناسه فایل درون پایگاه داده.
* `num_reads`: تعداد کل عملیات خواندن که روی فایل انجام شده است.
* `num_writes`: تعداد کل عملیات نوشتن که روی فایل انجام شده است.
* `num_bytes_read`: تعداد کل بایت‌های خوانده شده از فایل.
* `num_bytes_written`: تعداد کل بایت‌های نوشته شده در فایل.
* `io_stall_read_ms`: مجموع زمان بر حسب میلی‌ثانیه که درخواست‌های خواندن برای تکمیل منتظر بوده‌اند.
* `io_stall_write_ms`: مجموع زمان بر حسب میلی‌ثانیه که درخواست‌های نوشتن برای تکمیل منتظر بوده‌اند.
* `io_stall_overall_ms`: مجموع زمان توقف I/O (شامل خواندن و نوشتن).

این ستون‌ها به شما کمک می‌کنند تا گلوگاه‌های I/O را شناسایی کنید. به عنوان مثال، اگر `io_stall_read_ms` یا `io_stall_write_ms` مقادیر بالایی را نشان می‌دهند، این نشان‌دهنده این است که فایل در انتظار تکمیل عملیات I/O زیادی است که می‌تواند ناشی از کندی دیسک، اشغال بیش از حد کنترل‌کننده‌های ذخیره‌سازی یا حتی مشکلات پیکربندی RAID باشد.

مجموع زمان توقف I/O (`io_stall_overall_ms`) به سادگی مجموع زمان‌های توقف خواندن و نوشتن است:

io_stall_overall_ms = io_stall_read_ms + io_stall_write_ms

برای به دست آوردن یک دیدگاه جامع‌تر و قابل تفسیرتر، معمولاً `fn_virtualfilestats` را با `sys.databases` و `sys.master_files` ترکیب می‌کنند. این کار به شما امکان می‌دهد نام دیتابیس و نام فایل را در کنار آمارهای I/O مشاهده کنید، که خوانایی و تجزیه و تحلیل را به شدت بهبود می‌بخشد.


SELECT
DB_NAME(vfs.database_id) AS DatabaseName,
mf.name AS LogicalFileName,
mf.physical_name AS PhysicalFileName,
vfs.num_reads,
vfs.num_writes,
vfs.num_bytes_read,
vfs.num_bytes_written,
vfs.io_stall_read_ms,
vfs.io_stall_write_ms,
vfs.io_stall_overall_ms,
-- محاسبه میانگین زمان توقف برای هر عملیات خواندن
(vfs.io_stall_read_ms / (vfs.num_reads + 1.0)) AS AvgReadStall_ms,
-- محاسبه میانگین زمان توقف برای هر عملیات نوشتن
(vfs.io_stall_write_ms / (vfs.num_writes + 1.0)) AS AvgWriteStall_ms,
-- نسبت عملیات خواندن به نوشتن
CAST(vfs.num_reads AS DECIMAL(18,2)) / (vfs.num_writes + 1.0) AS ReadWriteRatio
FROM
sys.dm_io_virtual_file_stats(NULL, NULL) AS vfs
JOIN
sys.master_files AS mf ON vfs.database_id = mf.database_id AND vfs.file_id = mf.file_id
ORDER BY
vfs.io_stall_overall_ms DESC;

در این کوئری، `sys.dm_io_virtual_file_stats` یک DMV معادل با `fn_virtualfilestats` است که از SQL Server 2005 به بعد در دسترس است و در اکثر موارد توصیه می‌شود. این کوئری نه تنها آمار خام را ارائه می‌دهد، بلکه ستون‌های محاسبه شده‌ای مانند `AvgReadStall_ms` و `AvgWriteStall_ms` را نیز شامل می‌شود که میانگین زمان توقف برای هر عملیات I/O را نشان می‌دهد. این میانگین‌ها به شما کمک می‌کنند تا مشکلات مربوط به کندی I/O را با دقت بیشتری تشخیص دهید. نسبت خواندن به نوشتن (`ReadWriteRatio`) نیز بینشی در مورد الگوی دسترسی به فایل ارائه می‌دهد.

به یاد داشته باشید که نتایج `fn_virtualfilestats` (و `sys.dm_io_virtual_file_stats`) از زمان راه‌اندازی سرویس SQL Server یا آخرین باری که پایگاه داده آنلاین شده است، تجمعی هستند. اگر نیاز به نظارت بر I/O در یک دوره زمانی خاص دارید، باید در طول زمان، اسنپ‌شات‌هایی از داده‌ها بگیرید و آن‌ها را با هم مقایسه کنید.

**نتیجه‌گیری:**
`fn_virtualfilestats` ابزاری ضروری برای هر مدیر پایگاه داده SQL Server است که به دنبال بهینه‌سازی عملکرد I/O و شناسایی مشکلات مرتبط با دیسک است. با استفاده صحیح از این تابع و تحلیل دقیق خروجی آن، می‌توانید تصمیمات آگاهانه‌ای برای بهبود عملکرد سیستم ذخیره‌سازی، تنظیمات فایل‌های دیتابیس و در نهایت ارتقای تجربه کاربران خود بگیرید. استفاده از این ابزار برای مانیتورینگ منظم I/O و شناسایی زودتر مشکلات، می‌تواند جلوی بسیاری از مشکلات عملکردی دیتابیس را بگیرد.

 

fn_virtualfilestatsFunctionsI/O
Comments (0)
Add Comment