sql server怎么排查死锁优化性能-亚博电竞手机版

sql server怎么排查死锁优化性能

本篇内容主要讲解“sqlserver怎么排查死锁优化性能”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“sqlserver怎么排查死锁优化性能”吧!

一.概述

记得以前客户在使用软件时,有偶发出现死锁问题,因为发生的时间不确定,不好做问题的重现,当时解决问题有点棘手了。现总结下查看死锁的常用二种方式。

1.1 第一种是图形化监听:

sqlserver -->工具--> sql server profiler 登录后在跟踪属性中选择如下图:

监听到的死锁图形如下图

这里的描述大致是:有二个进程 一个进程id是96, 另一个id是348. 系统自动kill 掉了进程id:96,保留了进程id:348 的事务commit。

上面死锁是由于批量更新出现pag范围锁, 双方进程在同一分区索引资源上。id96,348都请求想获取更新锁(u),各占排它锁(x)不释放,直到锁超时。

1.2 第二种是使用日志跟踪(errorlog)

以全局方式打开指定的跟踪标记

dbcctraceon(1222,-1)dbcctraceon(1204,-1)

使用 exec master..xp_readerrorlog 查看日志。

deadlockencountered....printingdeadlockinformationwait-forgraphnullnode:1page:7:1:6229275cleancnt:2mode:ixflags:0x3grantlist3:owner:0x00000004e99b7880mode:ixflg:0x40ref:1life:02000000spid:219ecid:0xactlockinfo:0x0000000575c7e970spid:219ecid:0statementtype:updateline#:84inputbuf:languageevent:execproc_pub_stockdataimportrequestedby:restype:lockownerstype:'or'xdes:0x0000000c7a905d30mode:uspid:64batchid:0ecid:59taskproxy:(0x0000000e440aafe0)value:0x8d160240cost:(0/0)nullnode:2page:7:1:5692366cleancnt:2mode:uflags:0x3grantlist3:owner:0x0000000d12099b80mode:uflg:0x40ref:0life:00000001spid:64ecid:0xactlockinfo:0x000000136b4758f0spid:64ecid:0statementtype:updateline#:108inputbuf:rpcevent:proc[databaseid=7objectid=907150277]

node:1 部分显示的几个关键信息:

page 7:1:6229275(所在数据库id 7, 1分区, 6229275行数)

mode: ix 锁的模式 意向排它锁

spid: 219 进程id

event: exec proc_pub_stockdataimport 执行的存储过程名

node:2 部分显示的几个关键信息

page 7:1:5692366 (所在数据库id 7, 1分区,5692366行数)

mode:u锁的模式 更新锁

rpc event: proc 远程调用

spid: 64 进程id

victimresourceowner:restype:lockownerstype:'or'xdes:0x0000000c7a905d30mode:uspid:64batchid:0ecid:59taskproxy:(0x0000000e440aafe0)value:0x8d160240cost:(0/0)deadlock-listdeadlockvictim=process956f4c8process-listprocessid=process956f4c8taskpriority=0logused=0waitresource=page:7:1:6229275waittime=2034ownerid=2988267079transactionname=updatelasttranstarted=2018-04-19t13:54:00.360xdes=0xc7a905d30lockmode=uschedulerid=24kpid=1308status=suspendedspid=64sbid=0ecid=59priority=0trancount=0lastbatchstarted=2018-04-19t13:53:58.033lastbatchcompleted=2018-04-19t13:53:58.033clientapp=.netsqlclientdataproviderhostname=vmserver76hostpid=16328isolationlevel=readcommitted(2)xactid=2988267079currentdb=7locktimeout=4294967295clientoption1=671088672clientoption2=128056executionstackframeprocname=test.dbo.proc_cnofstockline=108stmtstart=9068stmtend=9336sqlhandle=0x03000700c503123601ba25019ca800000100000000000000updatedbo.pub_stocksetupdatetime=getdate()frompub_stockajoinpub_platfromstocktempbona.guid=b.stockguid

从上面的信息能看到kill 掉的是进程id是process956f4c8,

进程spid=64

lockmode=u 获取更新锁

isolationlevel=read committed

executionstack 执行的堆信息:

存储名 procname=test.dbo.proc_cnofstock

语句 update dbo.pub_stock set updatetime=getdate() ..

clientapp 发起事件的来源

1.3 最后总结 避免死锁的解决方法

按同一顺序访问对象。

优化索引,避免全表扫描,减少锁的申请数目.

避免事务中的用户交互。

使用基于行版本控制的隔离级别。

将事务默认隔离级别的已提交读改成快照

set transaction isolation level snapshot

使用nolock去掉共享锁,但死锁发生在u锁或x锁上,则nolock不起作用

升级锁颗粒度(页锁,表锁), 以阻塞还代替死锁

到此,相信大家对“sqlserver怎么排查死锁优化性能”有了更深的了解,不妨来实际操作一番吧!这里是恰卡编程网网站,更多相关内容可以进入相关频道进行查询,关注亚博电竞手机版,继续学习!

展开全文
内容来源于互联网和用户投稿,文章中一旦含有亚博电竞手机版的联系方式务必识别真假,本站仅做信息展示不承担任何相关责任,如有侵权或涉及法律问题请联系亚博电竞手机版删除

最新文章

网站地图