SQL Server死锁检测与SQL Server结束死锁概述

此文章主要介绍的是SQL Server死锁检测与SQL Server结束死锁,我们大家都知道在 Microsoft® SQL Server™ 2000 数据库中,单个用户会话可能有一个或多个代表它运行的线程。每个线程可能获取或等待获取各种资源,如:

为隆回等地区用户提供了全套网页设计制作服务,及隆回网站建设行业解决方案。主营业务为成都网站制作、成都做网站、隆回网站设计,以传统方式定制建设网站,并提供域名空间备案等一条龙服务,秉承以专业、用心的态度为用户提供真诚的服务。我们深信只要达到每一位用户的要求,就会得到认可,从而选择与我们长期合作。这样,我们也可以走得更远!

锁。

与并行查询执行相关的资源(与交换端口相关联的处理协调器、发生器和使用者线程)。

线程。

内存。

上述这些资源除内存外都参与 SQL Server死锁检测方案。对于内存,SQL Server 使用基于超时的机制,该机制由 sp_configure 中的 query wait 选项控制。

在 SQL Server 2000 中,死锁检测由一个称为锁监视器线程的单独的线程执行。在出现下列任一情况时,锁监视器线程对特定线程启动死锁搜索:

线程已经为同一资源等待了一段指定的时间。锁监视器线程定期醒来并识别所有等待某个资源的线程。如果锁监视器再次醒来时这些线程仍在等待同一资源,则它将对等待线程启动锁搜索。

线程等待资源并启动急切的死锁搜索。

SQL Server 通常只执行定期SQL Server死锁检测,而不使用急切模式。因为系统中遇到的死锁数通常很少,定期SQL Server死锁检测有助于减少系统中死锁检测的开销。

当锁监视器对特定线程启动死锁检测时,它识别线程正在等待的资源。然后,锁监视器查找特定资源的拥有者,并递归地继续执行对那些线程的死锁搜索,直到找到一个循环。用这种方式识别的循环形成一个死锁。

在识别死锁后,SQL Server 通过自动选择可以打破死锁的线程(死锁牺牲品)来结束死锁。SQL Server 回滚作为死锁牺牲品的事务,通知线程的应用程序(通过返回 1205 号错误信息),取消线程的当前请求,然后允许不间断线程的事务继续进行。

SQL Server 通常选择运行撤消时花费最少的事务的线程作为死锁牺牲品。另外,用户可以使用 SET 语句将会话的 DEADLOCK_PRIORITY 设置为 LOW。DEADLOCK_PRIORITY 选项控制在死锁情况下如何衡量会话的重要性。如果会话的设置为 LOW ,则当会话陷入死锁情况时将成为首选牺牲品。

识别死锁:识别死锁后,SQL Server 选择特定的线程作为死锁牺牲品,并返回一条列出死锁中涉及的资源的错误信息。该死锁信息采用下列形式:

Your transaction (process ID #52) was deadlocked>死锁中涉及的线程和资源位于错误日志中。

以上的相关内容就是对SQL Server死锁检测和结束死锁的介绍,望你能有所收获。

上述的相关内容就是对SQL Server死锁检测和结束死锁的描述,希望会给你带来一些帮助在此方面。

【编辑推荐】

  1. SQL Server 2008数据库中的联机事务处
  2. SQL Server磁带备份设备的性能优化过程
  3. SQL Server 2000数据库备份和还原的示例
  4. SQL Server 2005商业智能功能浅析
  5. 创建SQL Server数据库更是实在

本文题目:SQL Server死锁检测与SQL Server结束死锁概述
URL网址:http://www.mswzjz.cn/qtweb/news15/14415.html

攀枝花网站建设、攀枝花网站运维推广公司-贝锐智能,是专注品牌与效果的网络营销公司;服务项目有等

广告

声明:本网站发布的内容(图片、视频和文字)以用户投稿、用户转载内容为主,如果涉及侵权请尽快告知,我们将会在第一时间删除。文章观点不代表本网站立场,如需处理请联系客服。电话:028-86922220;邮箱:631063699@qq.com。内容未经允许不得转载,或转载时需注明来源: 贝锐智能