SqlServer数据库死锁排查方法

1. 开启数据库死锁日志功能

1.1 在SQLSERVER企业管理器里执行下面 a 命令,开启死锁日志

--a. 开启跟踪死锁
DBCC TRACEON(3605,1204,1222,-1)

--b. 关闭信号跟踪
DBCC TRACEOFF(1222,-1)
DBCC TRACEOFF(1204,-1)

--c. 查看信号跟踪是否开启。
DBCC TRACESTATUS(1204,-1)
DBCC TRACESTATUS(1222,-1)

1.2 执行命令后,如果发生死锁,可以在数据库日志 或者数据库自带的报表上查询死锁日志

 a. 在数据库安装目录下找到日志进行分析

           errorlog-> deadlock

 b.直接通过企业管理器查询SqlServer日志

a、b两个方法都是查看的同一份日志,任选其一即可。

日志中的关键字 dead  、 victim 

2. exec p_lockinfo 0

p_lockinfo 为根据数据库自带的信息表,组织的存储过程


3. SqlProfiler

用sqlserver 自带的工具sqlprofiler 跟踪SqlServer语句执行过程,选用DeadLock模板进行跟踪;

如果发现死锁,SqlProfiler会给出详细的语句,以及死锁的资源,是分析和解决死锁利器!

附相关学习文档链接

https://blog.csdn.net/weixin_42579642/article/details/84136322
https://www.cnblogs.com/iamconan/p/7383529.html
https://blog.csdn.net/danfeixia/article/details/40127841
https://www.cnblogs.com/rush/archive/2012/02/19/2358209.html
https://docs.microsoft.com/zh-cn/sql/relational-databases/system-stored-procedures/sp-lock-transact-sql?redirectedfrom=MSDN&view=sql-server-ver15

  • 2
    点赞
  • 16
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值