sql server偶发出现死锁的解决方法


Posted in SQL Server onApril 10, 2022

一.概述

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

1.1 第一种是图形化监听:

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

sql server偶发出现死锁的解决方法

监听到的死锁图形如下图

sql server偶发出现死锁的解决方法

sql server偶发出现死锁的解决方法

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

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

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

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

DBCC TRACEON(1222,-1)
DBCC TRACEON(1204,-1)

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

Deadlock encountered .... Printing deadlock information
Wait-for graph
NULL
Node:1 
PAGE: 7:1:6229275 CleanCnt:2 Mode:IX Flags: 0x3
Grant List 3:
Owner:0x00000004E99B7880 Mode: IX Flg:0x40 Ref:1 Life:02000000 SPID:219 ECID:0 XactLockInfo: 0x0000000575C7E970
SPID: 219 ECID: 0 Statement Type: UPDATE Line #: 84
Input Buf: Language Event: exec proc_PUB_StockDataImport
Requested by: 
ResType:LockOwner Stype:'OR'Xdes:0x0000000C7A905D30 Mode: U SPID:64 BatchID:0 ECID:59 TaskProxy:(0x0000000E440AAFE0) Value:0x8d160240 Cost:(0/0)
NULL

Node:2 
PAGE: 7:1:5692366 CleanCnt:2 Mode:U Flags: 0x3
Grant List 3:
Owner:0x0000000D12099B80 Mode: U Flg:0x40 Ref:0 Life:00000001 SPID:64 ECID:0 XactLockInfo: 0x000000136B4758F0
SPID: 64 ECID: 0 Statement Type: UPDATE Line #: 108
Input Buf: RPC Event: Proc [Database Id = 7 Object Id = 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

Victim Resource Owner:
ResType:LockOwner Stype:'OR'Xdes:0x0000000C7A905D30 Mode: U SPID:64 BatchID:0 ECID:59 TaskProxy:(0x0000000E440AAFE0) Value:0x8d160240 Cost:(0/0)
deadlock-list
deadlock victim=process956f4c8
process-list
process id=process956f4c8 taskpriority=0 logused=0 waitresource=PAGE: 7:1:6229275 waittime=2034 ownerId=2988267079 transactionname=UPDATE 
lasttranstarted=2018-04-19T13:54:00.360 XDES=0xc7a905d30 lockMode=U schedulerid=24 kpid=1308 status=suspended spid=64 sbid=0 ecid=59 priority=0 trancount=0 
lastbatchstarted=2018-04-19T13:53:58.033 lastbatchcompleted=2018-04-19T13:53:58.033 clientapp=.Net SqlClient Data Provider hostname=VMSERVER76 hostpid=16328 
isolationlevel=read committed (2) xactid=2988267079 currentdb=7 lockTimeout=4294967295 clientoption1=671088672 clientoption2=128056
executionStack
frame procname=Test.dbo.proc_CnofStock line=108 stmtstart=9068 stmtend=9336 sqlhandle=0x03000700c503123601ba25019ca800000100000000000000
update dbo.pub_stock
set UpdateTime=GETDATE()
from pub_stock a
join PUB_PlatfromStocktemp b on a.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不起作用

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

到此这篇关于sql server排查死锁优化性能的文章就介绍到这了。希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

SQL Server 相关文章推荐
SqlServer: 如何更改表的文件组?(进而改变存储位置)
Apr 05 SQL Server
SQLServer2019 数据库环境搭建与使用的实现
Apr 08 SQL Server
SQLServer2008提示评估期已过解决方案
Apr 12 SQL Server
sqlserver2017共享功能目录路径不可改的解决方法
Apr 16 SQL Server
SqlServer数据库远程连接案例教程
Jul 15 SQL Server
SQL Server表分区删除详情
Oct 16 SQL Server
SQL Server2019数据库备份与还原脚本,数据库可批量备份
Nov 20 SQL Server
SQLServer权限之只开启创建表权限
Apr 12 SQL Server
使用 MybatisPlus 连接 SqlServer 数据库解决 OFFSET 分页问题
Apr 22 SQL Server
SQL Server 忘记密码以及重新添加新账号
Apr 26 SQL Server
SQL Server中使用表变量和临时表
May 20 SQL Server
SQL bool盲注和时间盲注详解
Jul 23 SQL Server
SQL Server的存储过程与触发器以及系统函数和自定义函数
Apr 10 #SQL Server
SQL Server表分区降低运维和维护成本
SQL Server使用导出向导功能
SQL Server内存机制浅探
sqlserver连接错误之SQL评估期已过的问题解决
SQL Server远程连接的设置步骤(图文)
SQLServer RANK() 排名函数的使用
You might like
DC动漫人物排行
2020/03/03 欧美动漫
为什么那些咖啡爱好者大多看不上连锁咖啡店?
2021/03/06 咖啡文化
PHP实现图片压缩的两则实例
2014/07/19 PHP
PHP排序算法之堆排序(Heap Sort)实例详解
2018/04/21 PHP
可缩放Reloaded-一个针对可缩放元素的复用组件
2007/03/10 Javascript
js不完美解决click和dblclick事件冲突问题
2012/07/16 Javascript
JS小游戏之极速快跑源码详解
2014/09/25 Javascript
javascript瀑布流式图片懒加载实例
2020/06/28 Javascript
JS实现倒计时(天数、时、分、秒)
2016/11/16 Javascript
一篇文章搞定JavaScript类型转换(面试常见)
2017/01/21 Javascript
Javascript同时声明一连串(多个)变量的方法
2017/01/23 Javascript
canvas实现十二星座星空图
2017/02/14 Javascript
JS实现的四级密码强度检测功能示例
2017/05/11 Javascript
es6+angular1.X+webpack 实现按路由功能打包项目的示例
2017/08/16 Javascript
详解plotly.js 绘图库入门使用教程
2018/02/23 Javascript
Vue.js样式动态绑定实现小结
2019/01/24 Javascript
vue v-for循环重复数据无法添加问题解决方法【加track-by='索引'】
2019/03/15 Javascript
微信小程序自定义组件传值 页面和组件相互传数据操作示例
2019/05/05 Javascript
element-ui tooltip修改背景颜色和箭头颜色的实现
2019/12/16 Javascript
vue iview 隐藏Table组件里的某一列操作
2020/11/13 Javascript
利用Python的Flask框架来构建一个简单的数字商品支付解决方案
2015/03/31 Python
Python下的常用下载安装工具pip的安装方法
2015/11/13 Python
django自带serializers序列化返回指定字段的方法
2019/08/21 Python
英国水族馆和池塘用品购物网站:Warehouse Aquatics
2019/08/29 全球购物
网络编程中设计并发服务器,使用多进程与多线程,请问有什么区别?
2016/03/27 面试题
大三在校生电子商务求职信
2013/10/29 职场文书
化学专业毕业生自荐信
2013/11/15 职场文书
应聘收银员个人的求职信
2013/11/30 职场文书
《陋室铭》教学反思
2014/02/26 职场文书
向领导表决心的话
2014/03/11 职场文书
教师个人自我评价范文
2014/04/13 职场文书
诚信承诺书
2015/01/19 职场文书
国庆庆典邀请函
2015/02/02 职场文书
推广普通话宣传标语口号
2015/12/26 职场文书
《地震中的父与子》教学反思
2016/02/16 职场文书
《最后一头战象》教学反思
2016/02/16 职场文书