SQL Server 死锁的监视

SQL Server 中,如果出现了两个事务相互等待对方释放资源,就会出现死锁。后启动的事务或者死锁优先级较低的事务将会被牺牲,提交被牺牲的事务的应用程序会出现异常。

2010527115823921.jpg

那么如何监视SQL Server 发生的死锁事件呢?

SQL Server Profiler提供了一组事件,可以收集到发生的死锁事件,并清楚的展现死锁的原因和处理结果。实现的方法如下:

1、打开SQL Server Profiler,新建跟踪,连接到发生死锁的服务器;

2、选择“TSQL_Locks”跟踪模板

3、点击“事件选择”,可以看到其中几个关键事件——SQL:StmtStarting(TSQL)SP:StmtStarting(Stored Procedures)Deadlock graph(Locks) Lock:Deadlock(Locks)Lock:Deadlock Chain(Locks)

4、点击“运行”,开始跟踪

在跟踪到死锁之后,可以再Profiler中看到下面的死锁相关事件发生:

2010527115949705.jpg

选择Profiler中的Deadlock graph 事件,可以看到下面的图形:

201052712311313.jpg

该图形表示左侧的被标识为X的事务被牺牲了,X箭头表示事务对对象有排他锁,U箭头表示事务请改对象

201052712341239.jpg

将鼠标放在椭圆形的事务上,可以显示导致死锁发生的语句。

当然,在我们跟踪到死锁之后,需要解决死锁的问题,还需要下面的方法:

通过索引优化查询

事务尽可能的简短

尽量以相同的顺序访问对象

如果允许的话,使用较低的隔离级别进行访问


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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值