SQL Server阻塞诊断

在数据仓库维护过程中,经常会出现定时更新程序和查询SQL发生冲突而引起阻塞的情况,需要进行SQL Server诊断。

SQL Server诊断一般会用到2个视图:sys.sysprocesses(系统进程表) 和sys.dm_exec_sql_text(系统执行内容表) 。

通过查看当前运行的进程信息可以查看阻塞的情况:

SELECT   spid,
         blocked,
         DB_NAME(sp.dbid) AS DBName,
         program_name,
         waitresource,
         lastwaittype,
         sp.loginame,
         sp.hostname,
         a.[Text] AS [TextData]
FROM     sys.sysprocesses AS sp OUTER APPLY sys.dm_exec_sql_text (sp.sql_handle) AS A
WHERE    spid > 50
ORDER BY blocked DESC, DB_NAME(sp.dbid) ASC, a.[text];

其中

spid:SQL Server的会话ID,因spid<=50的为SQL Server本身的系统进程,所以这里取spid>50;
blocked:正在阻塞求情的会话 ID,如果此列为0,则标识请求未被阻塞;
DB_NAME(sp.dbid):当前正由进程使用的数据库名称;
Program_name:应用程序的名称,连接字符串中配的Application Name;
Loginame:登录名;
Hostname:建立链接的客户端工作站的名称;
Text:当前运行的SQL语句。

当找到阻塞进程后,可以使用如下命令结束该进程:
kill spid

铸剑团队签名:

【总监】十二春秋之,3483099@qq.com

【Master】戈稻不苍,han169@126.com

【Java开发】雨鸶,343691194@qq.com;思齐骏惠,qiangzhang1227@163.com;小王子,545106057@qq.com;巡山小钻风,840260821@qq.com

【VS开发】豆点,2268800211@qq.com

【系统测试】土镜问道,847071279@qq.com;尘子与自由,695187655@qq.com

【大数据】沙漠绿洲,caozhipan@126.com张三省,570417591@qq.com

【网络】夜孤星,11297761@qq.com

【系统运营】三石头,261453882@qq.com;平凡怪咖,591169003@qq.com

【容灾备份】秋天的雨,18568921@qq.com

【安全】保密,你懂的。

原创作者:张三省

著作权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。

 

原文地址:https://www.cnblogs.com/zhangleisanshi/p/8024934.html