SQL Server 死锁故障排除,第二部分

SQL Server 死锁故障排除,第二部分

原文:Deadlock Troubleshooting, Part 2

在这篇博文中,将检视一个实际的死锁,然后使用在SQL Server 死锁故障排除,第一部分中描述的步骤解决它,以便你可以看到它们的实际效果。这是一个微软的内部客户要求协助解决的,死锁场景的简化版本。要建立此场景,运行下面的SQL:

 

       -- Batch #1

       CREATE DATABASE deadlocktest

       GO

       USE deadlocktest

       SET NOCOUNT ON

       DBCC TRACEON (1222, -1)

       GO

       IF OBJECT_ID ('t1') IS NOT NULL DROP TABLE t1

       IF OBJECT_ID ('p1') IS NOT NULL DROP PROC p1

       IF OBJECT_ID ('p2') IS NOT NULL DROP PROC p2

       GO

       CREATE TABLE t1 (c1 int, c2 int, c3 int, c4 char(5000))

       GO

       DECLARE @x int

       SET @x = 1

       WHILE (@x <= 1000) BEGIN

             INSERT INTO t1 VALUES (@x*2, @x*2, @x*2, @x*2)

             SET @x = @x + 1

       END

       GO

       CREATE CLUSTERED INDEX cidx ON t1 (c1)

       CREATE NONCLUSTERED INDEX idx1 ON t1 (c2)

       GO

       CREATE PROC p1 @p1 int AS

             SELECT c2, c3 FROM t1 WHERE c2 BETWEEN @p1 AND @p1+1

       GO

       CREATE PROC p2 @p1 int AS

       UPDATE t1 SET c2 = c2+WHERE c1 = @p1

       UPDATE t1 SET c2 = c2-WHERE c1 = @p1

       GO

 

现在从另外一个连接运行下面的SQL:

       -- Batch #2

       USE deadlocktest

       SET NOCOUNT ON

       WHILE (1=1)

             EXEC p2 4

       GO

 

最后,保持上面的脚本运行的同时,从第三个连接运行下面的SQL:

       -- Batch #3

       USE deadlocktest

       SET NOCOUNT ON

       CREATE TABLE #t1 (c2 int, c3 int)

       GO

       WHILE (1=1) BEGIN

             INSERT INTO #t1 EXEC p1 4

             TRUNCATE TABLE #t1

       END

       GO

 

这会引起一个死锁,你应该看见其中一个批处理被一个1205错误强制退出。现在我们有一个可复现的死锁,可遵循SQL Server 死锁故障排除,第一部分博文中解决问题的步骤。

 

  1. 启用追踪标志 1222(译注:执行DBCC TRACEON (1222, -1))  该设置脚本已经为你作为一个全局标志打开追踪标志(在dbcc traceon命令中,这“-1”是关键)。
  2. 得到-T1222输出(译注:打开YourMSSQLInstallDir\MSSQL\Log下的ERRORLOG文件,搜索关键字“1222”)  现在看看你的错误日志,你应该看到描述死锁的追踪标志1222输出。
  3. 解码-T1222输出  再一次通读SQL Server 死锁故障排除,第一部分,如果你需要更多的有关如何解释-T1222或-T1204的输出。此处是你在筛选-T1222的细节后,最终抽取的最重要的花絮:

    Spid X is running this query (line 2 of proc [p1], inputbuffer “… EXEC p1 4 …”):
    SELECT c2, c3 FROM t1 WHERE c2 BETWEEN @p1 AND @p1+1
    Spid Y is running this query (line 2 of proc [p2], inputbuffer “EXEC p2 4”):
    UPDATE t1 SET c2 = c2+1 WHERE c1 = @p1

    Spid X is waiting for a Shared KEY lock on index t1.cidx.  Spid Y holds a conflicting X lock.
    Spid Y is waiting for an eXclusive KEY lock on index t1.idx1.  Spid X holds a conflicting S lock.

  4. 通过数据库引擎优化顾问运行查询(译注:打开待分析的批查询,在查询窗口右点打开快捷菜单,选择“数据库引擎优化顾问中的分析查询”菜单项,打开“数据库引擎优化顾问”实用程序,在“常规”选项卡的“选择要优化的数据库和表”区域,指定要优化的数据库,但后单击工具栏的“开始分析”按钮执行分析  切换到“建议”选项卡可以看到推荐的建议,使用主菜单的“操作”-“应用建议”应用优化顾问建议,或“保存建议”将来使用)。-T1222输出告诉我们,在死锁的时候我们正在运行什么inputbuffer (输入缓存)(“EXEC p1 4”和“EXEC p2 4”)。使用在SQL Server 死锁故障排除,第一部分中讨论的步骤,在DTA(database engine tuning advisor)中,调优每一个查询。DTA(database engine tuning advisor)会为Batch 3推荐一个新的索引。通过从动作下拉列表菜单,选择“Apply Recommendations”,创建这个索引。

 

这时候,如果你重新运行批处理2和批处理3,你会发现死锁已经解决。你甚至不需要使用5-8步骤,或者我在该系列博文的第一部分的列表中地其它死锁规避策略。

 

在随后的博文中,我会检视,在这个特殊的死锁中查询计划的细节,方便理解是什么原因引起死锁,以及为什么DTA(database engine tuning advisor)的建议索引修复了它。

SQL Server 死锁故障排除,第一部分
SQL Server 死锁故障排除,第二部分
SQL Server 死锁故障排除,第三部分
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
完整清晰 PDF 扫描文档 这个PDF文件是我花钱买来的,现在为了挣积分,拿出来与大家分享!! -------------------------------------------------------------------------------- SQL Server 2008高级程序设计 2/6 SQL Server 2008 2010 高级程序设计 作者:(美)维埃拉 著,杨华,腾灵灵 译 出版社:清华大学 出版日期:2010-4-1 ISBN:9787302222729 字数:1250000 页码:730 -------------------------------------------------------------------------------- 内容提要 -------------------------------------------------------------------------------- Microsoft SQL Server 2008极大地完善了数据库引擎的核心组件,也改变了数据库应用程序的构建方式。《SQL Server 2008高级程序设计》由世界顶尖SQL Server权威专家Robert Vieira编写,旨在指导您熟练运用一系列日趋复杂的功能,助您更高效地管理数据。   本书首先介绍SQL Server 2008的新功能,然后在更详实的示例代码的引导下全面深入地展开论述,讨论了如何编写复杂查询、构建各种数据结构以及提高应用程序性能,还讲述了如何管理高级脚本和数据库以及如何确定和改正脚本错误。   本书提供了快速创建和部署数据驱动的解决方案来满足业务需求的信息,介绍了新数据类型、索引结构、管理功能和高级时区处理等重要内容,掌握这些知识后,您将使自己的数据库发挥㈩最大功效。   主要内容   ◆除规范化外的数据设计技巧   ◆尽量提高应用程序运行速度的方法   ◆有关存储过程和用户定义函数的全部内容   ◆存储过程的高级处理方法   ◆报表服务和集成服务的用法   ◆提高数据库安全性的提示信息   ◆如何利用XML和XQuery支持   ◆通过修改特定数据值进行推理分析的步骤   读者对象   本书面向想要学用所有SQL Server 2008功能的有经验的开发人员。 目录 -------------------------------------------------------------------------------- 第1章 回顾SQL Server中的对象  1.1 数据库的构成  1.2 数据库对象概述  1.3 SQL Server数据类型  1.4 SQL Server对象标识符  1.5 小结 第2章 工具  2.1 联机丛书  2.2 SQL Server配置管理器  2.3 SQL Server Management Studio  2.4 SQL Server Business Intelligence Development Studio  2.5 SQL Server集成服务(SSIS)  2.6 Reporting Services  2.7 BulkCopy Program(bcp)  2.8 SQL Server Profiler  2.9 sqlcmd  2.10 小结 第3章 提出更好的问题:高级查询  3.1 子查询概述  3.2 构建嵌套子查询  3.3 相关子查询  3.4 派生表  3.5 EXISTS运算符  3.6 INTERSECT和EXCEPT运算符  3.7 通用表表达式(CTE)  3.8 递归查询  3.9 合并  3.10 利用外部调用完成复杂操作  3.11 性能考虑  3.12 小结 第4章 XML集成  4.1 XML数据类型  4.2 提取XML格式的关系数据  4.3 有关XML索引的提示  4.4 层次数据概述  4.5 小结 第5章 细心推敲,大胆设计  5.1 进一步了解规范化  5.2 关系  5.3 图表  5.4 逻辑设计与物理设计  5.5 通过经典的BLOB处理基于文件的信息  5.6 子类别  5.7 数据库重用  5.8 反规范化  5.9 通过分区方法进行扩展  5.10 SQL Server关系图工具  5.11 关于日期列  5,12 小结 第6章 核心存储和索引结构  6.1 SQL Server存储  6.2 理解索引  6.3 创建、修改和删除索引  6.4 明智地决定何时何地使用何种索引  6.5 维护索引  6.6 小结 第7章

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值