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

posted on   中道学友  阅读(2370)  评论(1编辑  收藏  举报

编辑推荐:
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
· 基于Microsoft.Extensions.AI核心库实现RAG应用
· Linux系列:如何用heaptrack跟踪.NET程序的非托管内存泄露
· 开发者必知的日志记录最佳实践
· SQL Server 2025 AI相关能力初探
阅读排行:
· 震惊!C++程序真的从main开始吗?99%的程序员都答错了
· 【硬核科普】Trae如何「偷看」你的代码?零基础破解AI编程运行原理
· 单元测试从入门到精通
· 上周热点回顾(3.3-3.9)
· winform 绘制太阳,地球,月球 运作规律
历史上的今天:
2009-07-28 Linux基本命令篇- 网络管理2
2009-07-28 [转]激活root帐号并允许登录
2009-07-28 [转]REST是什么

导航

< 2010年7月 >
27 28 29 30 1 2 3
4 5 6 7 8 9 10
11 12 13 14 15 16 17
18 19 20 21 22 23 24
25 26 27 28 29 30 31
1 2 3 4 5 6 7

技术追求准确,态度积极向上

点击右上角即可分享
微信分享提示