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 相关文章推荐
解决sql server 数据库,sa用户被锁定的问题
Jun 11 SQL Server
SQL Server代理:理解SQL代理错误日志处理方法
Jun 30 SQL Server
数据库之SQL技巧整理案例
Jul 07 SQL Server
sql通过日期判断年龄函数的示例代码
Jul 16 SQL Server
sql server删除前1000行数据的方法实例
Aug 30 SQL Server
万能密码的SQL注入漏洞其PHP环境搭建及防御手段
Sep 04 SQL Server
Windows环境下实现批量执行Sql文件
Oct 05 SQL Server
通过T-SQL语句创建游标与实现数据库加解密功能
Mar 16 SQL Server
如何使用SQL Server语句创建表
Apr 12 SQL Server
SQL Server携程核心系统无感迁移到MySQL实战
Jun 01 SQL Server
详解SQL报错盲注
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
PHP采集类snoopy详细介绍(snoopy使用教程)
2014/06/19 PHP
PHP与Java对比学习日期时间函数
2016/07/03 PHP
Laravel中的chunk组块结果集处理与注意问题
2018/08/15 PHP
thinkPHP5.1框架使用SemanticUI实现分页功能示例
2019/08/03 PHP
MooTools 1.2中的Drag.Move来实现拖放
2009/09/15 Javascript
jquery退出each循环的写法
2014/02/26 Javascript
中文输入法不触发onkeyup事件的解决办法
2014/07/09 Javascript
Bootstrap开关(switch)控件学习笔记分享
2016/05/30 Javascript
jQuery实现微信长按识别二维码功能
2016/08/26 Javascript
nodejs中使用HTTP分块响应和定时器示例代码
2017/03/19 NodeJs
Angular.JS内置服务$http对数据库的增删改使用教程
2017/05/07 Javascript
vue实现商城上货组件简易版
2017/11/27 Javascript
将jquery.qqFace.js表情转换成微信的字符码
2017/12/01 jQuery
js计算两个日期间的天数月的实例代码
2018/09/20 Javascript
微信小程序左滑删除功能开发案例详解
2018/11/12 Javascript
vue + any-touch实现一个iscroll 实现拖拽和滑动动画效果
2019/04/08 Javascript
React 全自动数据表格组件——BodeGrid的实现思路
2019/06/12 Javascript
通过layer实现可输入的模态框的例子
2019/09/27 Javascript
JavaScript实现动态生成表格
2020/08/02 Javascript
解决vue项目,npm run build后,报路径错的问题
2020/08/13 Javascript
[00:27]DOTA2次级职业联赛 - Lilith战队宣传片
2014/12/01 DOTA
[02:02]特效爆炸!DOTA2珍宝之瓶待你开启
2018/08/21 DOTA
使用python删除nginx缓存文件示例(python文件操作)
2014/03/26 Python
春节到了 教你使用python来抢票回家
2020/01/06 Python
VS2019+python3.7+opencv4.1+tensorflow1.13配置详解
2020/04/16 Python
HTML5里autofocus自动聚焦属性使用介绍
2016/06/22 HTML / CSS
捷克浴室和厨房设备购物网站:SIKO
2018/08/11 全球购物
英国露营设备和户外服装购物网站:Simply Hike
2019/05/05 全球购物
八年级美术教学反思
2014/02/02 职场文书
研究生给导师的自荐信
2015/03/06 职场文书
培训计划通知
2015/07/15 职场文书
2019年个人工作总结范文(3篇)
2019/08/27 职场文书
蔬果开业典礼发言稿应该怎么写?
2019/09/03 职场文书
Springboot如何使用logback实现多环境配置?
2021/06/16 Java/Android
Nginx静态压缩和代码压缩提高访问速度详解
2022/05/30 Servers
彻底弄懂Python中的回调函数(callback)
2022/06/25 Python