iis服务器助手广告广告
返回顶部
首页 > 资讯 > 精选 >SQL Server的死锁是什么及怎么结束
  • 557
分享到

SQL Server的死锁是什么及怎么结束

2023-07-06 01:07:16 557人浏览 安东尼
摘要

本文小编为大家详细介绍“sql Server的死锁是什么及怎么结束”,内容详细,步骤清晰,细节处理妥当,希望这篇“SQL Server的死锁是什么及怎么结束”文章能帮助大家解决疑惑,下面跟着小编的思路慢慢深入,一起来学习

本文小编为大家详细介绍“sql Server的死是什么及怎么结束”,内容详细,步骤清晰,细节处理妥当,希望这篇“SQL Server的死锁是什么及怎么结束”文章能帮助大家解决疑惑,下面跟着小编的思路慢慢深入,一起来学习新知识吧。

    一、了解死锁

    死锁是导致数据库中的竞争性并发锁,通常在多步骤事务中。
    当两个或多个任务永久相互阻止时,每个任务都锁定了其他任务尝试锁定的资源,就会发生死锁。例如:

    • 事务 A 获取第 1 行上的共享锁。

    • 事务 B 获取第 2 行上的共享锁。

    • 事务 A 现在请求第 2 行上的独占锁,并被阻止,直到事务 B 完成并释放第 2 行上的共享锁。

    • 事务 B 现在请求第 1 行上的独占锁,并被阻止,直到事务 A 完成并释放它在第 1 行上的共享锁。

    事务 A 在事务 B 完成之前无法完成,但事务 B 被事务 A 阻止。此条件也称为循环依赖关系:事务 A 依赖于事务 B,事务 B 通过对事务 A 的依赖来关闭循环。

    死锁中的两个事务将永远等待,除非死锁被外部进程打破。SQL Server 数据库引擎死锁监视器定期检查处于死锁状态的任务。如果监视器检测到循环依赖关系,它将选择其中一个任务作为受害者,并在出现错误的情况下终止其事务。这允许其他任务完成其事务。具有因错误而终止的事务的应用程序可以重试该事务,该事务通常在另一个死锁事务完成后完成。

    死锁经常与正常阻塞混淆。当一个事务请求锁定另一个事务锁定的资源时,请求事务将等待,直到锁定被释放。默认情况下,除非设置了LOCK_TIMEOUT,否则 SQL Server 事务不会超时。请求事务被阻止,而不是死锁,因为请求事务没有执行任何操作来阻止拥有锁的事务。最终,拥有事务将完成并释放锁,然后请求事务将被授予锁定并继续。死锁几乎可以立即解决,而阻塞理论上可以无限期地持续存在。僵局有时被称为致命的拥抱。

    死锁是可能发生在具有多个线程的任何系统上的情况,而不仅仅是在关系数据库管理系统上,并且可能发生在数据库对象上的锁以外的资源上。例如,多线程操作系统中的线程可能会获取一个或多个资源,例如内存块。如果要获取的资源当前由另一个线程拥有,则第一个线程可能必须等待拥有该线程释放目标资源。据说等待线程依赖于该特定资源的拥有线程。在 SQL Server 数据库引擎实例中,会话在获取非数据库资源(如内存或线程)时可能会死锁。

    SQL Server的死锁是什么及怎么结束

    在图中,事务 T1 依赖于表锁资源的事务 T2。同样,事务 T2 依赖于表锁资源的事务 T1。由于这些依赖项形成一个循环,因此事务 T1 和 T2 之间存在死锁。

    当对表进行分区并将 的设置设置为 AUTO 时,也会发生死锁。设置为 AUTO 时,通过允许 SQL Server 数据库引擎在 HoBT 级别而不是表级别锁定表分区,并发性会增加。但是,当单独的事务在表中持有分区锁并希望在其他事务分区上的某个位置使用锁时,这会导致死锁。这种类型的死锁可以通过设置为 ;尽管此设置将通过强制对分区进行大量更新以等待表锁定来降低并发性。

    二、检测并结束死锁

    当两个或多个任务永久相互阻止时,每个任务都锁定了其他任务尝试锁定的资源,就会发生死锁。下图显示了死锁状态的高级视图,其中:

    • 任务 T1 锁定了资源 R1(由从 R1 到 T1 的箭头指示),并请求锁定资源 R2(由从 T1 到 R2 的箭头指示)。

    • 任务 T2 锁定了资源 R2(由从 R2 到 T2 的箭头指示),并请求锁定资源 R1(由从 T2 到 R1 的箭头指示)。

    • 由于在资源可用之前,这两个任务都无法继续,并且在任务继续之前无法释放这两个资源,因此存在死锁状态。

    SQL Server的死锁是什么及怎么结束

    SQL Server 数据库引擎会自动检测 SQL Server 中的死锁周期。SQL Server 数据库引擎选择其中一个会话作为死锁受害者,当前事务将终止,并显示错误以打破死锁。

    2.1、可能死锁的资源

    每个用户会话可能代表其运行一个或多个任务,其中每个任务可能获取或等待获取各种资源。以下类型的资源可能会导致阻塞,从而导致死锁。

    • 锁。等待获取资源(如对象、页面、行、元数据和应用程序)的锁可能会导致死锁。例如,事务 T1 在行 r1 上具有共享 (S) 锁,并且正在等待在 r2 上获取独占 (X) 锁。事务 T2 在 r2 上具有共享 (S) 锁,并且正在等待在行 r1 上获取独占 (X) 锁。这会导致锁定循环,其中 T1 和 T2 相互等待对方释放锁定的资源。

    • 工作线程。等待可用工作线程的排队任务可能会导致死锁。如果排队的任务拥有阻止所有工作线程的资源,则会导致死锁。例如,会话 S1 启动事务并在行 r1 上获取共享 (S) 锁,然后进入睡眠状态。在所有可用工作线程上运行的活动会话正在尝试获取行 r1 上的独占 (X) 锁。由于会话 S1 无法获取工作线程,因此它无法提交事务并释放行 r1 上的锁。这会导致死锁。

    • 内存。当并发请求正在等待可用内存无法满足的内存授予时,可能会发生死锁。例如,两个并发查询 Q1 和 Q2 作为用户定义的函数执行,分别获取 10 MB 和 20 MB 的内存。如果每个查询需要 30 MB,总可用内存为 20 MB,则 Q1 和 Q2 必须等待对方释放内存,这会导致死锁。

    • 与并行查询执行相关的资源。与交换端口关联的协调器、生产者或使用者线程可能会相互阻塞,从而导致死锁,通常是在包含至少一个不属于并行查询一部分的其他进程时。此外,当并行查询开始执行时,SQL Server 会根据当前工作负荷确定并行度或工作线程数。如果系统工作负荷意外更改(例如,新查询开始在服务器上运行或系统工作线程不足),则可能会发生死锁。

    • 多个活动结果集 (MARS) 资源。用户资源、会话互斥锁、事务互斥锁等这些资源用于控制 MARS 下多个活动请求的交错。

    为了使任务在 MARS 下运行,它必须获取会话互斥锁。如果任务在事务下运行,则必须获取事务互斥锁。这保证在给定会话和给定事务中一次只有一个任务处于活动状态。获取所需的互斥锁后,任务就可以执行。当任务完成或在请求中间产生时,它将首先释放事务互斥锁,然后以相反的获取顺序释放会话互斥锁。但是,这些资源可能会发生死锁。在以下伪代码中,两个任务(用户请求 U1 和用户请求 U2)在同一会话中运行。

    从用户请求 U1 执行的存储过程已获取会话互斥锁。如果存储过程需要很长时间才能执行,则 SQL Server 数据库引擎假定存储过程正在等待用户的输入。用户请求 U2 正在等待会话互斥锁,而用户正在等待来自 U2 的结果集,U1 正在等待用户资源。这是死锁状态,逻辑上说明为:

    SQL Server的死锁是什么及怎么结束

    三、处理死锁

    当 SQL Server 数据库引擎实例选择某个事务作为死锁受害者时,它将终止当前批处理,回滚该事务,并向应用程序返回错误消息 1205。

    由于提交 Transact-SQL 查询的任何应用程序都可以被选为死锁受害者,因此应用程序应具有可以捕获错误消息 1205 的错误处理程序。如果应用程序未捕获错误,则应用程序可以在不知道其事务已回滚并可能发生错误的情况下继续操作。

    实现捕获错误消息 1205 的错误处理程序允许应用程序处理死锁情况并采取补救措施(例如,自动重新提交死锁中涉及的查询)。通过自动重新提交查询,用户无需知道发生了死锁。

    在重新提交查询之前,应用程序应短暂暂停。这使死锁中涉及的其他事务有机会完成并释放构成死锁循环一部分的锁。这样可以最大程度地降低在重新提交的查询请求其锁时再次发生死锁的可能性。

    四、最大限度地减少死锁

    尽管无法完全避免死锁,但遵循某些编码约定可以最大程度地减少生成死锁的可能性。最小化死锁可以提高事务吞吐量并减少系统开销,因为事务较少:

    • 回滚,撤消事务执行的所有工作。

    • 由应用程序重新提交,因为它们在死锁时已回滚。

    要帮助最大程度地减少死锁,请执行以下操作:

    • 以相同的顺序访问对象。

    • 避免事务中的用户交互;保持交易简短且批量。

    • 使用较低的隔离级别。

    • 使用基于行版本控制的隔离级别。将数据库选项设置为启用已提交的读取事务以使用行版本控;使用快照隔离。

    • 使用绑定连接。

    4.1、以相同的顺序访问对象

    如果所有并发事务都以相同的顺序访问对象,则不太可能发生死锁。例如,如果两个并发事务在表上获取锁,然后在表上获得锁,则一个事务在表上被阻止,直到另一个事务完成。第一个事务提交或回滚后,第二个事务将继续,并且不会发生死锁。对所有数据修改使用存储过程可以标准化访问对象的顺序。

    SQL Server的死锁是什么及怎么结束

    4.2、避免事务中的用户交互

    避免编写包含用户交互的事务,因为无需用户干预即可运行的批处理的速度比用户必须手动响应查询(例如回复应用程序请求的参数提示)的速度快得多。例如,如果事务正在等待用户输入,并且用户周末去吃午饭甚至回家,则用户会延迟事务完成。这会降低系统吞吐量,因为事务持有的任何锁仅在提交或回滚事务时释放。即使没有出现死锁情况,访问相同资源的其他事务也会在等待事务完成时被阻止。

    4.3、保持交易简短且在一个批次中

    当多个长时间运行的事务在同一数据库中同时执行时,通常会发生死锁。事务时间越长,独占锁或更新锁的持有时间就越长,从而阻止其他活动并导致可能的死锁情况。

    将事务保存在一个批次中可最大程度地减少事务期间的网络往返,从而减少完成事务和释放锁定时可能出现的延迟。

    4.4、使用较低的隔离级别

    确定事务是否可以在较低的隔离级别运行。实现 read commit 允许事务读取先前由另一个事务读取(未修改)的数据,而无需等待第一个事务完成。与较高的隔离级别(如可序列化)相比,使用较低的隔离级别(如已提交的读取)保留共享锁的持续时间更短。这减少了锁定争用。

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

    当数据库选项设置为 ON 时,在读取提交隔离级别下运行的事务在读取操作期间使用行版本控制而不是共享锁。
    快照隔离还使用行版本控制,在读取操作期间不使用共享锁。在事务可以在快照隔离下运行之前,必须设置数据库选项ALLOW_SNAPSHOT_ISOLATioNON。

    实现这些隔离级别,以最大程度地减少读取和写入操作之间可能发生的死锁。

    4.6、使用绑定连接

    使用绑定连接,同一应用程序打开的两个或多个连接可以相互协作。辅助连接获取的任何锁都像由主连接获取一样保存,反之亦然。因此,它们不会相互阻塞。

    4.7、停止事务

    在死锁方案中,受害事务会自动停止并回滚。在死锁情况下无需停止事务。

    读到这里,这篇“SQL Server的死锁是什么及怎么结束”文章已经介绍完毕,想要掌握这篇文章的知识点还需要大家自己动手实践使用过才能领会,如果想了解更多相关内容的文章,欢迎关注编程网精选频道。

    --结束END--

    本文标题: SQL Server的死锁是什么及怎么结束

    本文链接: https://www.lsjlt.com/news/357160.html(转载时请注明来源链接)

    有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

    本篇文章演示代码以及资料文档资料下载

    下载Word文档到电脑,方便收藏和打印~

    下载Word文档
    猜你喜欢
    • SQL Server的死锁是什么及怎么结束
      本文小编为大家详细介绍“SQL Server的死锁是什么及怎么结束”,内容详细,步骤清晰,细节处理妥当,希望这篇“SQL Server的死锁是什么及怎么结束”文章能帮助大家解决疑惑,下面跟着小编的思路慢慢深入,一起来学习...
      99+
      2023-07-06
    • Sql Server中怎么监控死锁
      本篇文章给大家分享的是有关Sql Server中怎么监控死锁,小编觉得挺实用的,因此分享给大家学习,希望大家阅读完这篇文章后可以有所收获,话不多说,跟着小编一起来看看吧。死锁的xml文件如下:<dea...
      99+
      2024-04-02
    • sql server中怎么排查死锁
      sql server中怎么排查死锁,针对这个问题,这篇文章详细介绍了相对应的分析和解答,希望可以帮助更多想解决这个问题的小伙伴找到更简单易行的方法。死锁的四个必要条件:互斥条件(Mutual exclusi...
      99+
      2024-04-02
    • sql死锁的原因及解决方法是什么
      SQL死锁是指在多个并发事务中,每个事务都在等待其他事务所持有的资源,导致所有事务都无法继续执行的状态。死锁的原因主要有以下几种:1...
      99+
      2023-08-16
      sql
    • MySQL死锁是什么及怎么掌握
      这篇“MySQL死锁是什么及怎么掌握”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看这篇“MySQ...
      99+
      2024-04-02
    • sql server怎么排查死锁优化性能
      本篇内容主要讲解“sql server怎么排查死锁优化性能”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“sql server怎么排查死锁优化性能”吧!一.概述记得以前客户在使...
      99+
      2023-06-29
    • SQL Server中的约束有什么用
      SQL Server中的约束用于限制对数据库表中数据的插入、更新和删除操作,以确保数据的完整性和一致性。约束可以定义在列级别或表级别...
      99+
      2023-08-17
      SQL Server
    • sql server中意向锁的作用是什么
      本篇文章给大家分享的是有关sql server中意向锁的作用是什么,小编觉得挺实用的,因此分享给大家学习,希望大家阅读完这篇文章后可以有所收获,话不多说,跟着小编一起来看看吧。  sql server中意向...
      99+
      2024-04-02
    • Python死锁指的是什么
      小编给大家分享一下Python死锁指的是什么,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!python主要应用领域有哪些1、云计算,典型应用OpenStack。2...
      99+
      2023-06-14
    • SQL Server 中怎么创建约束
      今天就跟大家聊聊有关SQL Server 中怎么创建约束,可能很多人都不太了解,为了让大家更加了解,小编给大家总结了以下内容,希望大家根据这篇文章可以有所收获。什么是主键?在数据库中,常常不只是一个表,这些...
      99+
      2024-04-02
    • java中什么是死锁
      java中什么是死锁?相信很多没有经验的人对此束手无策,为此本文总结了问题出现的原因和解决方法,通过这篇文章希望你能解决这个问题。Java可以用来干什么Java主要应用于:1. web开发;2. Android开发;3. 客户端开发;4. ...
      99+
      2023-06-14
    • 死锁概念是什么
      死锁是指在并发计算中,两个或多个进程因为互相等待对方释放资源而陷入无限等待的状态,导致系统无法继续执行下去,死锁是一种资源竞争的情况,其中每个参与者都在等待其他参与者释放资源,但由于彼此之间的相互依赖,导致没有一个参与者能够继续执行。本教程...
      99+
      2023-08-17
    • SQL Server主键约束怎么创建
      这篇“SQL Server主键约束怎么创建”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看...
      99+
      2024-04-02
    • sql死锁问题怎么解决
      本篇内容介绍了“sql死锁问题怎么解决”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成! --查询锁表信息,...
      99+
      2024-04-02
    • mysql死锁排查及解决的方法是什么
      MySQL死锁是指两个或多个事务相互等待对方持有的资源,导致无法继续执行的情况。为了排查和解决MySQL死锁,可以采取以下方法:1....
      99+
      2023-08-16
      mysql
    • SQL Server数据存储结构是什么
      这期内容当中小编将会给大家带来有关SQL Server数据存储结构是什么,文章内容丰富且以专业的角度为大家分析和叙述,阅读完这篇文章希望大家可以有所收获。文件类型  数据库在磁盘上是以文件为单位存储的,由数...
      99+
      2024-04-02
    • SQL Server是什么
      本篇内容主要讲解“SQL Server是什么”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“SQL Server是什么”吧! SQLServer的版本 它最初...
      99+
      2024-04-02
    • golang中什么是死锁?怎么避免?
      一、什么是死锁?在并发编程中,当两个或多个进程(线程)相互等待对方的资源释放时,就会产生死锁(Deadlock)。简单来说,就是每个进程都占用了一部分资源,同时需要等待对方释放资源,以完成自己的任务,但是对方也一样,这时候就会造成死循环式的...
      99+
      2023-05-14
    • 死锁是怎么产生的
      这篇文章主要讲解了“死锁是怎么产生的”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“死锁是怎么产生的”吧!Part1 问题由于innodb engine st...
      99+
      2024-04-02
    • SQL Server中怎么实现约束增强
      SQL Server中怎么实现约束增强,相信很多没有经验的人对此束手无策,为此本文总结了问题出现的原因和解决方法,通过这篇文章希望你能解决这个问题。在许多情况下,对外键使用更复杂的逻辑表达式是非常有用的。 ...
      99+
      2024-04-02
    软考高级职称资格查询
    编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
    • 官方手机版

    • 微信公众号

    • 商务合作