SQL Activity Monitor
生活随笔
收集整理的這篇文章主要介紹了
SQL Activity Monitor
小編覺得挺不錯的,現在分享給大家,幫大家做個參考.
從實質上說, Actvity Monitor不過是SQL中系統表sys.sysprocesses的一種展現.
?
可以使用如下的語句來獲得與activity monitor相同的輸出.
select * from sys.sysprocesses where spid > 50
and status = ‘suspended’
?
select * from distinct lastwaittype from sys.sysprocesses where spid > 50
and status = ‘syspended’
?
在sys.sysprocesses表中, status列很重要, 不同Process的ID對應的可能的值如下:
- dormant = SQL Server 正在重置session
- running = Session正在運行一個或多個批處理(batch). 當Multiple Active Result Sets (MARS) 處于開啟的狀態下, 一個session可以運行多個batch.
- background = Session正在運行一個后臺任務, 比如說死鎖檢測(dead lock detection).
- rollback = Session正在進行一個回滾的操作(rollback)
- pending = Session正在等待出現一個可用的work thread.
- runnable = Session中的任務正在定式作業管理器的runnable的隊列中, 等待一個時間片, 即等待CPU處理.
- spinloop = session中的任務正在等待一個自旋鎖(spinlock)的釋放.
- suspended = The session is waiting for an event, such as I/O, to complete.Session正在等待一個事件的完成, 比如說IO.
SQL系統自己的spid都是小于等于50的, 大于50的spid都是來自于應用程序的.
?
參考資料:
http://msdn.microsoft.com/en-us/library/ms179881.aspx?
http://msdn.microsoft.com/en-us/library/ms178520%28SQL.90%29.aspx
總結
以上是生活随笔為你收集整理的SQL Activity Monitor的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 乐Phone:还原联想的联想
- 下一篇: 自己做回CA 给别人发证