sysprocesses در SQL Server پایش فعالیت‌ها و رفع Blocking راهنمای جامع

شناخت عمیق sysprocesses در SQL Server: راه جامع مدیریت و پایش فعالیت‌ها

در SQL Server، sysprocesses یکی از قدیمی‌ترین و بنیادی‌ترین Views/جداول سیستمی است که اطلاعاتی درباره فرآیندهای در حال اجرا روی Instance SQL Server ارائه می‌دهد. اگرچه DMV‌های (Dynamic Management Views) جدیدتر مانند sys.dm_exec_requests و sys.dm_exec_sessions اطلاعات جامع‌تری ارائه می‌دهند، sysprocesses همچنان جایگاه خود را برای بررسی‌های سریع و سازگاری، به ویژه با اسکریپت‌های قدیمی‌تر، حفظ کرده است. درک sysprocesses یک مهارت حیاتی برای هر مدیر پایگاه داده SQL Server یا توسعه‌دهنده‌ای است که به دنبال عیب‌یابی مشکلات عملکردی یا نظارت بر فعالیت سرور است.

ستون‌های کلیدی در sysprocesses

بیایید نگاهی به برخی از پرکاربردترین ستون‌ها در sysprocesses بیندازیم:

  • spid (Server Process ID): یک شناسه منحصربه‌فرد برای هر فرآیند کاربر. این شناسه کلید اصلی برای sysprocesses است.
  • kpid (Kernel Process ID): شناسه رشته ویندوز (در صورت وجود) برای رشته کاری (worker thread).
  • blocked: شناسه spid فرآیند blockکننده (blocking process)، اگر این فرآیند block شده باشد. اگر blocked برابر با 0 باشد، فرآیند block نیست.
  • waittype, waittime, waitresource: اطلاعاتی درباره اینکه فرآیند در انتظار چه چیزی است.
  • lastwaittype: نوع آخرین انتظار.
  • cmd: دستوری که در حال حاضر در حال اجراست (مثلاً SELECT, INSERT, UPDATE, DELETE, AWAITING COMMAND).
  • loginame: نام کاربری که فرآیند را آغاز کرده است.
  • hostname: نام ایستگاه کاری (client workstation).
  • program_name: نام برنامه‌ای که اتصال را آغاز کرده است.
  • hostprocess: شناسه فرآیند برنامه کلاینت.
  • status: وضعیت فرآیند (مثلاً running, sleeping, runnable, suspended).
  • open_tran: تعداد تراکنش‌های باز برای فرآیند.
  • cpu, physical_io, memusage: معیارهای مصرف منابع.
  • login_time: زمان اتصال فرآیند.
  • last_batch: زمان ارسال آخرین دسته (batch).

نحوه کوئری گرفتن از sysprocesses

می‌توانید از sysprocesses درست مانند هر View یا جدول دیگری کوئری بگیرید:


SELECT *
FROM sys.sysprocesses;

این کوئری ساده، تمامی ستون‌ها و ردیف‌های موجود در Viewی سیستمی sysprocesses را بازیابی می‌کند و یک دید کلی از وضعیت همه فرآیندهای فعال و غیرفعال ارائه می‌دهد.

فیلتر کردن برای فرآیندهای فعال

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


SELECT
    spid,
    status,
    blocked,
    waittype,
    waittime,
    lastwaittype,
    cmd,
    loginame,
    hostname,
    program_name
FROM sys.sysprocesses
WHERE status NOT IN ('sleeping', 'background')
  AND spid > 50 -- Filter out system processes
ORDER BY blocked DESC, spid;

این کوئری فرآیندهایی را که در حالت ‘sleeping’ یا ‘background’ نیستند و spid آنها بزرگتر از 50 است (برای حذف فرآیندهای سیستمی داخلی)، Viewیش می‌دهد. همچنین نتایج بر اساس ستون blocked مرتب شده‌اند تا فرآیندهای block شده به‌راحتی قابل مشاهده باشند.

شناسایی Blocking در SQL Server

یکی از قدرتمندترین کاربردهای sysprocesses، شناسایی سریع blocking است. اگر ستون blocked یک فرآیند مقدار غیرصفر را نشان دهد، به این معنی است که آن فرآیند منتظر spid نشان داده شده در ستون blocked است. این یک ابزار کلیدی برای عیب‌یابی مشکلات عملکردی است.


SELECT
    p1.spid AS BlockedSPID,
    p1.loginame AS BlockedLogin,
    p1.cmd AS BlockedCommand,
    p2.spid AS BlockingSPID,
    p2.loginame AS BlockingLogin,
    p2.cmd AS BlockingCommand,
    p2.waittype AS BlockingWaittype,
    p2.waitresource AS BlockingWaitResource
FROM sys.sysprocesses p1
JOIN sys.sysprocesses p2 ON p1.blocked = p2.spid
WHERE p1.blocked  0;

این کوئری فرآیندهای block شده را همراه با اطلاعات فرآیند blockکننده Viewیش می‌دهد؛ چه کسی block شده، توسط چه کسی، و فرآیند blockکننده در حال انجام چه کاری است. این رویکرد به شما کمک می‌کند تا به سرعت علت اصلی blocking و تأثیر آن بر عملکرد پایگاه داده را تشخیص دهید.

مقایسه با DMVs

در حالی که sysprocesses مفید است، نسخه‌های مدرن SQL Server (2005 و بالاتر) Viewsی  (DMVs) را معرفی کرده‌اند که اطلاعات جامع‌تر و بلادرنگ‌تری ارائه می‌دهند. به عنوان مثال، sys.dm_exec_requests و sys.dm_exec_sessions معمولاً برای بهینه‌سازی دقیق عملکرد ترجیح داده می‌شوند.
با این حال، sysprocesses برای بررسی‌های سریع همچنان ساده‌تر است و در برخی سناریوها سربار کمتری دارد، که آن را به یک نقطه شروع خوب برای تشخیص‌های اولیه تبدیل می‌کند. همچنین، این View فاقد جزئیاتی مانند sql_handle یا plan_handle است که DMVs ارائه می‌دهند. برای نظارت دقیق‌تر و جمع‌آوری داده‌های عمیق‌تر، استفاده ترکیبی از هر دو ابزار توصیه می‌شود.

نتیجه‌گیری

sysprocesses یک Viewی سیستمی قدیمی اما همچنان ارزشمند در SQL Server است. این ابزار یک Viewی کلی سریع از فعالیت سرور ارائه می‌دهد که برای شناسایی فرآیندهای فعال، blocking و مصرف منابع بسیار مهم است. اگرچه DMVs داده‌های غنی‌تری ارائه می‌دهند، درک sysprocesses یک مهارت بنیادی برای متخصصان SQL Server باقی می‌ماند. سادگی و دسترسی سریع آن به اطلاعات اصلی، این ابزار را حتی امروز نیز برای عیب‌یابی اولیه و نظارت، مرتبط نگه می‌دارد. استفاده از sysprocesses به عنوان گام اول در تحلیل عملکرد می‌تواند به سرعت شما را به سمت فرآیندهای مشکل‌ساز هدایت کند و تجربه مدیریت SQL Server شما را بهبود بخشد.

 

sql serverاموزش SqlServer
Comments (0)
Add Comment