阿里云开发者社区

电脑版
提示:原网页已由神马搜索转码, 内容由developer.aliyun.com提供.

sqlserver死锁排查

2024-04-2571
版权
版权声明:
本文内容由阿里云实名注册用户自发贡献,版权归原作者所有,阿里云开发者社区不拥有其著作权,亦不承担相应法律责任。具体规则请查看《 阿里云开发者社区用户服务协议》和 《阿里云开发者社区知识产权保护指引》。如果您发现本社区中有涉嫌抄袭的内容,填写 侵权投诉表单进行举报,一经查实,本社区将立刻删除涉嫌侵权内容。
本文涉及的产品
RDS SQL Server Serverless,2-4RCU 50GB 3个月
推荐场景:
云数据库 RDS SQL Server,基础系列 2核4GB
简介:sqlserver死锁排查

检查锁定表的sql的id,并不一定是死锁,因为只要锁定表就会被查出来,得是多次出现才能推测是死锁

select     request_session_id spid,       OBJECT_NAME(resource_associated_entity_id) tableName    from     sys.dm_tran_locks   where     resource_type='OBJECT'

查询死锁语句

DBCC INPUTBUFFER(54)

查询sqlserver错误日志

EXEC xp_ReadErrorLog 0, 1

删除死锁进程

kill pid

查询历史死锁

DECLARE @SessionName SysName  SELECT @SessionName = 'system_health'  IF OBJECT_ID('tempdb..#Events') IS NOT NULL BEGIN    DROP TABLE #EventsEND DECLARE @Target_File NVarChar(1000)    , @Target_Dir NVarChar(1000)    , @Target_File_WildCard NVarChar(1000) SELECT @Target_File = CAST(t.target_data as XML).value('EventFileTarget[1]/File[1]/@name', 'NVARCHAR(256)')FROM sys.dm_xe_session_targets t    INNER JOIN sys.dm_xe_sessions s ON s.address = t.event_session_addressWHERE s.name = @SessionName    AND t.target_name = 'event_file' SELECT @Target_Dir = LEFT(@Target_File, Len(@Target_File) - CHARINDEX('\', REVERSE(@Target_File)))  SELECT @Target_File_WildCard = @Target_Dir + '\'  + @SessionName + '_*.xel' --Keep this as a separate table because it's called twice in the next query.  You don't want this running twice.SELECT DeadlockGraph = CAST(event_data AS XML)    , DeadlockID = Row_Number() OVER(ORDER BY file_name, file_offset)INTO #EventsFROM sys.fn_xe_file_target_read_file(@Target_File_WildCard, null, null, null) AS FWHERE event_data like '<event name="xml_deadlock_report%' ;WITH Victims AS(    SELECT VictimID = Deadlock.Victims.value('@id', 'varchar(50)')        , e.DeadlockID     FROM #Events e        CROSS APPLY e.DeadlockGraph.nodes('/event/data/value/deadlock/victim-list/victimProcess') as Deadlock(Victims)), DeadlockObjects AS(    SELECT DISTINCT e.DeadlockID        , ObjectName = Deadlock.Resources.value('@objectname', 'nvarchar(256)')    FROM #Events e        CROSS APPLY e.DeadlockGraph.nodes('/event/data/value/deadlock/resource-list/*') as Deadlock(Resources))SELECT *FROM(    SELECT e.DeadlockID        , TransactionTime = Deadlock.Process.value('@lasttranstarted', 'datetime')        , DeadlockGraph        , DeadlockObjects = substring((SELECT (', ' + o.ObjectName)                            FROM DeadlockObjects o                            WHERE o.DeadlockID = e.DeadlockID                            ORDER BY o.ObjectName                            FOR XML PATH ('')                            ), 3, 4000)        , Victim = CASE WHEN v.VictimID IS NOT NULL                             THEN 1                         ELSE 0                         END        , SPID = Deadlock.Process.value('@spid', 'int')        , ProcedureName = Deadlock.Process.value('executionStack[1]/frame[1]/@procname[1]', 'varchar(200)')        , LockMode = Deadlock.Process.value('@lockMode', 'char(1)')        , Code = Deadlock.Process.value('executionStack[1]/frame[1]', 'varchar(1000)')        , ClientApp = CASE LEFT(Deadlock.Process.value('@clientapp', 'varchar(100)'), 29)                        WHEN 'SQLAgent - TSQL JobStep (Job '                            THEN 'SQLAgent Job: ' + (SELECT name FROM msdb..sysjobs sj WHERE substring(Deadlock.Process.value('@clientapp', 'varchar(100)'),32,32)=(substring(sys.fn_varbintohexstr(sj.job_id),3,100))) + ' - ' + SUBSTRING(Deadlock.Process.value('@clientapp', 'varchar(100)'), 67, len(Deadlock.Process.value('@clientapp', 'varchar(100)'))-67)                        ELSE Deadlock.Process.value('@clientapp', 'varchar(100)')                        END         , HostName = Deadlock.Process.value('@hostname', 'varchar(20)')        , LoginName = Deadlock.Process.value('@loginname', 'varchar(20)')        , InputBuffer = Deadlock.Process.value('inputbuf[1]', 'varchar(1000)')    FROM #Events e        CROSS APPLY e.DeadlockGraph.nodes('/event/data/value/deadlock/process-list/process') as Deadlock(Process)        LEFT JOIN Victims v ON v.DeadlockID = e.DeadlockID AND v.VictimID = Deadlock.Process.value('@id', 'varchar(50)')) XORDER BY TransactionTime DESC


相关实践学习
使用SQL语句管理索引
本次实验主要介绍如何在RDS-SQLServer数据库中,使用SQL语句管理索引。
SQL Server on Linux入门教程
SQL Server数据库一直只提供Windows下的版本。2016年微软宣布推出可运行在Linux系统下的SQL Server数据库,该版本目前还是早期预览版本。本课程主要介绍SQLServer On Linux的基本知识。 相关的阿里云产品:云数据库RDS&nbsp;SQL Server版 RDS SQL Server不仅拥有高可用架构和任意时间点的数据恢复功能,强力支撑各种企业应用,同时也包含了微软的License费用,减少额外支出。 了解产品详情:&nbsp;https://www.aliyun.com/product/rds/sqlserver
目录
相关文章
|
1月前
|
SQL存储测试技术
SQL Server 查询超时问题排查
【8月更文挑战第14天】遇到SQL Server查询超时,先检查查询复杂度与索引使用;审视服务器CPU、内存及磁盘I/O负载;审查SQL Server配置与超时设置;检测锁和阻塞状况;最后审查应用代码与网络环境。每步定位问题根源,针对性优化以提升查询效率。务必先行备份并在测试环境验证改动。
|
2月前
|
SQL监控数据库
SQL Server 查询超时问题排查
【7月更文挑战第8天】排查 SQL Server 查询超时涉及五个主要方面:检查复杂查询、评估服务器性能、审视配置参数、更新统计信息和分析执行计划。关注点包括查询的结构(如连接、子查询和索引),服务器资源(CPU、内存、网络延迟),连接和内存设置,以及统计信息的时效性。通过这些步骤可定位并解决性能瓶颈。
|
SQL关系型数据库数据库
RDS for SQL server 空间问题排查汇总
SQL server的空间问题一直有客户在询问,今天就给大家汇总讲解下SQL server 的全部空间开销
RDS for SQL server 空间问题排查汇总
|
SQL测试技术C#
SQL Server死锁中的会话隔离级别为序列化(Serializable)实验测试
SQL Server死锁中的会话隔离级别为序列化(Serializable)实验测试最近在分析SQL Server的死锁时,发现一个比较有意思的现象,发现死锁当中一个会话的隔离级别为序列化(Serializable),这个是让人比较奇怪的地方,我们知道SQL Server数据库的默认隔离级别为已提交读(READ COMMITTED),除非人为设置事务隔离级别(TRANSACTION ISOLATION LEVEL),否则事务隔离级别会使用数据库的默认隔离级别。
2177400
|
关系型数据库索引RDS
用 ssms 排查 rds for sqlserver 性能问题
ssms 即Microsoft sqlserver management studio , 需要在本地安装后才能使用. 本文以 sqlserver 2017 management studio 工具排查日常使用中遇到的性能问题.
259800
|
SQL数据格式XML
SQL SERVER 查看近期死锁
SQL SERVER 查看近期死锁在项目运行的过程中,死锁不可能完全避免,但要尽可能减少死锁的出现, 产生死锁的原因主要是: 1,系统资源不足。 2,进程运行推进的顺序不合适。 3,资源分配不当等。 产生死锁的四个必要条件: 互斥条件:一个资源每次只能被一个进程使用,即在一段时间内某资源仅为一个进程所占有。
|
SQL监控Go
SQL Server 死锁的告警监控
原文:SQL Server 死锁的告警监控 今天这篇文章总结一下如何监控SQL Server的死锁,其实以前写过MS SQL 监控错误日志的告警信息,这篇文章着重介绍如何监控数据库的死锁,当然这篇文章不分析死锁产生的原因、以及如何解决死锁。
112800
|
SQLGo数据库
SQLSERVER排查CPU占用高的情况
SQLSERVER排查CPU占用高的情况 原文地址为:SQLSERVER排查CPU占用高的情况 今天中午,有朋友叫我帮他看一下数据库,操作系统是Windows2008R2 ,数据库是SQL2008R2 64位 64G内存,16核CPU 硬件配置还是比较高的,他说服务器运行的是金蝶K3软件,数据.
|
SQL关系型数据库Go
RDS SQL Server死锁(Deadlock)系列之一使用DBCC捕获死锁
RDS SQL Server死锁(Deadlock)系列之一使用DBCC捕获死锁http://www.bieryun.com/4528.html 问题引入 在日常运维阿里云RDS SQL Server产品过程中,经常会被客户问道:“应用程序被死锁报错啦?影响很大,到底是哪个进程导致了死锁发生的啊?怎么解决啊?怎么办呀?”。

热门文章

最新文章

  • 1
    数据分享|SQL Server、Visual Studio、tableau对信贷风险数据ETL分析、数据立方体构建可视化
    76
  • 2
    SQL Server仓储物流公司visual studio发货数据仓库设计
    48
  • 3
    SQL SERVER ANALYSIS SERVICES决策树、聚类、关联规则挖掘分析电商购物网站的用户行为数据
    106
  • 4
    SQL Server Analysis Services数据挖掘聚类分析职业、地区、餐饮消费水平数据
    69
  • 5
    SQL Server聚类数据挖掘信用卡客户可视化分析
    87
  • 6
    【Database】Sqlserver如何定时备份数据库和定时清除
    159
  • 7
    sqlserver行转列和列转行
    66
  • 8
    JavaScript云LIS系统源码ASP.NET CORE 3.1 MVC + SQLserver + Redis医院实验室信息系统源码 医院云LIS系统源码
    66
  • 9
    如何在 Windows 上安装 SQL Server,保姆级教程来了!
    401
  • 10
    C#开发的全套成熟的LIS系统源码JavaScript+SQLserver 2012区域云LIS系统源码
    49