admin管理员组文章数量:1794759
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 0p_lockinfo 为根据数据库自带的信表,组织的存储过程
3. SqlProfiler用sqlserver 自带的工具sqlprofiler 跟踪SqlServer语句执行过程,选用DeadLock模板进行跟踪;
如果发现死锁,SqlProfiler会给出详细的语句,以及死锁的资源,是分析和解决死锁利器!
附相关学习文档链接blog.csdn/weixin_42579642/article/details/84136322 wwwblogs/iamconan/p/7383529.html blog.csdn/danfeixia/article/details/40127841 wwwblogs/rush/archive/2012/02/19/2358209.html docs.microsoft/zh-cn/sql/relational-databases/system-stored-procedures/sp-lock-transact-sql?redirectedfrom=MSDN&view=sql-server-ver15
版权声明:本文标题:SqlServer数据库死锁排查方法 内容由林淑君副主任自发贡献,该文观点仅代表作者本人, 转载请联系作者并注明出处:http://www.xiehuijuan.com/baike/1686658762a91573.html, 本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌抄袭侵权/违法违规的内容,一经查实,本站将立刻删除。
发表评论