亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 數據庫 > SQL Server > 正文

MSSQL產生死鎖的根本原因及解決方法

2024-08-31 01:03:47
字體:
來源:轉載
供稿:網友
死鎖是指兩個或兩個以上的進程在執行過程中,因爭奪資源而造成的一種互相等待的現象,若無外力作用,它們都將無法推進下去.此時稱系統處于死鎖狀態或系統產生了死鎖,這些永遠在互相等的進程稱為死鎖進程
 

一、 什么是死鎖

死鎖是指兩個或兩個以上的進程在執行過程中,因爭奪資源而造成的一種互相等待的現象,若無外力作用,它們都將無法推進下去.此時稱系統處于死鎖狀態或系統產生了死鎖,這些永遠在互相等的進程稱為死鎖進程.

二、 死鎖產生的四個必要條件

•互斥條件:指進程對所分配到的資源進行排它性使用,即在一段時間內某資源只由一個進程占用。如果此時還有其它進程請求資源,則請求者只能等待,直至占有資源的進程用畢釋放

•請求和保持條件:指進程已經保持至少一個資源,但又提出了新的資源請求,而該資源已被其它進程占有,此時請求進程阻塞,但又對自己已獲得的其它資源保持不放

•不剝奪條件:指進程已獲得的資源,在未使用完之前,不能被剝奪,只能在使用完時由自己釋放

•環路等待條件:指在發生死鎖時,必然存在一個進程——資源的環形鏈,即進程集合{P0,P1,P2,···,Pn}中的P0正在等待一個P1占用的資源;P1正在等待P2占用的資源,……,Pn正在等待已被P0占用的資源

這四個條件是死鎖的必要條件,只要系統發生死鎖,這些條件必然成立,而只要上述條件之一不滿足,就不會發生死鎖。

三、 如何處理死鎖

1) 鎖模式

1.共享鎖(S)

由讀操作創建的鎖,防止在讀取數據的過程中,其它事務對數據進行更新;其它事務可以并發讀取數據。共享鎖可以加在表、頁、索引鍵或者數據行上。在SQL SERVER默認隔離級別下數據讀取完畢后就會釋放共享鎖,但可以通過鎖提示或設置更高的事務隔離級別改變共享鎖的釋放時間。

2.獨占鎖(X)

對資源獨占的鎖,一個進程獨占地鎖定了請求的數據源,那么別的進程無法在此數據源上獲得任何類型的鎖。獨占鎖一致持有到事務結束。

3.更新鎖(U)

更新鎖實際上并不是一種獨立的鎖,而是共享鎖與獨占鎖的混合。當SQL SERVER執行數據修改操作卻首先需要搜索表以找到需要修改的資源時,會獲得更新鎖。

更新鎖與共享鎖兼容,但只有一個進程可以獲取當前數據源上的更新鎖,

其它進程無法獲取該資源的更新鎖或獨占鎖,更新鎖的作用就好像一個序列化閥門(serialization gate),將后續申請獨占鎖的請求壓入隊列中。持有更新鎖的進程能夠將其轉換成該資源上的獨占鎖。更新鎖不足以用于更新數據—實際的數據修改仍需要用到獨占鎖。對于獨占鎖的序列化訪問可以避免轉換死鎖的發生,更新鎖會保留到事務結束或者當它們轉換成獨占鎖時為止。

4. 意向鎖(IX,IU,IS)

意向鎖并不是獨立的鎖定模式,而是一種指出哪些資源已經被鎖定的機制。

如果一個表頁上存在獨占鎖,那么另一個進程就無法獲得該表上的共享表鎖,這種層次關系是用意向鎖來實現的。進程要獲得獨占頁鎖、更新頁鎖或意向獨占頁鎖,首先必須獲得該表上的意向獨占鎖。同理,進程要獲得共享行鎖,必須首先獲得該表的意向共享鎖,以防止別的進程獲得獨占表鎖。

5. 特殊鎖模式(Sch_s,Sch_m,BU)

SQL SERVER提供3種額外的鎖模式:架構穩定鎖、架構修改鎖、大容量更新鎖。

6.轉換鎖(SIX,SIU,UIX)

轉換鎖不會由SQL SERVER 直接請求,而是從一種模式轉換到另一種模式所造成的。SQL SERVER 2008支持3種類型的轉換鎖:SIX、SIU、UIX.其中最常見的是SIX鎖,如果事務持有一個資源上的共享鎖(S),然后又需要一個IX鎖,此時就會出現SIX。

7.鍵范圍鎖

鍵范圍鎖是在可序列化隔離級別中鎖定一定范圍內數據的鎖。保證在查詢數據的鍵范圍內不允許插入數據。

 

SQL SERVER 鎖模式

縮寫

鎖模式

說明

S

Shared

允許其他進程讀取但不能修改鎖定的資源

X

Exclusive

防止別的進程讀取或者修改鎖定資源中的數據

U

Update

防止其它進程獲取更新鎖或獨占鎖;在搜索要修改的數據時使用

IS

Intent shared

表示該資源的一個組件被共享鎖鎖定了。只有在表或頁級別才能獲得這類鎖

IU

Intent update

表示該資源的一個組件被更新鎖鎖定了。只有在表或頁級別才能獲得這類鎖

IX

Intent exclusive

表示該資源的一個組件被獨占鎖鎖定了。只有在表或頁級別才能獲得這類鎖

SIX

Shared with intent exclusive

表示一個正持有共享鎖的資源還有一個組件(一頁或一行)被獨占鎖鎖定了

SIU

Shared with intent Update

表示一個正持有共享鎖的資源還有一個組件(一頁或一行)被更新鎖鎖定了

UIX

Update with intent exclusive

表示一個正持有更新鎖的資源還有一個組件(一頁或一行)被獨占鎖鎖定了

Sch-S

Schema stability

表示一個使用該表的查詢正在被編譯

Sch-M

Schema modification

表示表的結構正在被修改

BU

Bulk Update

在一個大容量復制操作將數據導入表中并且(手動或自動)應用了TABLOCK查

詢提示時使用

 

2) 鎖粒度

SQL SERVER 可以在表、頁、行等級別鎖定用戶的數據資源即非系統資源(系統資源是用閂鎖來保護的)。此外SQL SERVER 還可以鎖定索引鍵和索引鍵范圍。

通過sys.dm_tran_locks視圖可以查看誰被鎖定了(如行,鍵,頁)、鎖的模式以及特定資源的標志符?;趕ys.dm_tran_locks視圖創建如下視圖用于查看鎖定的資源以及鎖模式(通過這個視圖可以查看事務鎖定的表、頁、行以及加在數據資源上的鎖類型)。

CREATE VIEW dblocks AS SELECT request_session_id AS spid, DB_NAME(resource_database_id) AS dbname, CASE WHEN resource_type='object' THEN OBJECT_NAME(resource_associated_entity_id) WHEN resource_associated_entity_id=0 THEN 'n/a' ELSE OBJECT_NAME(p.object_id) END AS entity_name, index_id, resource_type AS RESOURCE, resource_description AS DESCRIPTION, request_mode AS mode, request_status AS STATUS FROM sys.dm_tran_locks t LEFT JOIN sys.partitions p ON p.partition_id=t.resource_associated_entity_id WHERE resource_database_id=DB_ID()

3) 如何跟蹤死鎖

通過選擇sql server profiler 事件中的如下選項就可以跟蹤到死鎖產生的相關語句。

4) 死鎖案例分析

在該案例中process65db88, process1d0045948為語句1的進程,process629dc8 為語句2的進程; 語句2獲取了1689766頁上的更新鎖,在等待1686247頁上的更新鎖;而語句1則獲取了1686247頁上的更新鎖在等待1689766頁上的更新鎖,兩個語句等待的資源形成了一個環路,造成死鎖。

5) 如何解決死鎖

針對如上死鎖案例,分析其對應語句執行計劃如下:

通過執行計劃可以看出,在查找需要更新的數據時使用的是索引掃描,比較耗費性能,這樣就造成鎖定資源時間過長,增加了語句并發執行時產生死鎖的概率。

處理方式:

1. 在表上建立一個聚集索引。

2. 對語句更新的相關字段建立包含索引。

優化后該語句執行計劃如下:

優化后的執行計劃使用了索引查找,將大幅提升該查詢語句的性能,降低了鎖定資源的時間,同時也減少了鎖定資源的范圍,這樣就降低了鎖資源循環等待事件發生的概率,對于預防死鎖的發生會有一定的作用。

死鎖是無法完全避免的,但如果應用程序適當處理死鎖,對涉及的任何用戶及系統其余部分的影響可降至最低(適當處理是指發生錯誤1205時,應用程序重新提交批處理,第二次嘗試大多能成功。一個進程被殺死,它的事務被取消,它的鎖被釋放,死鎖中涉及到的另一個進程就可以完成它的工作并釋放鎖,所以就不具備產生另一個死鎖的條件了。)

四、 如何預防死鎖

阻止死鎖的途徑就是避免滿足死鎖條件的情況發生,為此我們在開發的過程中需要遵循如下原則:

1.盡量避免并發的執行涉及到修改數據的語句。

2.要求每一個事務一次就將所有要使用到的數據全部加鎖,否則就不允許執行。

3.預先規定一個加鎖順序,所有的事務都必須按照這個順序對數據執行封鎖。如不同的過程在事務內部對對象的更新執行順序應盡量保證一致。

4.每個事務的執行時間不可太長,對程序段的事務可考慮將其分割為幾個事務。在事務中不要求輸入,應該在事務之前得到輸入,然后快速執行事務。

5.使用盡可能低的隔離級別。

6.數據存儲空間離散法。該方法是指采用各種手段,將邏輯上在一個表中的數據分散的若干離散的空間上去,以便改善對表的訪問性能。主要通過將大表按行或者列分解為若干小表,或者按照不同的用戶群兩種方法實現。

7.編寫應用程序,讓進程持有鎖的時間盡可能短,這樣其它進程就不必花太長的時間等待鎖被釋放。



注:相關教程知識閱讀請移步到MSSQL教程頻道。
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
亚洲白拍色综合图区| 欧美精品一区在线播放| 欧美理论电影网| 亚洲日韩欧美视频| 欧美日韩综合视频网址| 66m—66摸成人免费视频| 亚洲成人av片| 日韩中文在线中文网在线观看| 久久久精品国产网站| 91免费看国产| 国产精品久久国产精品99gif| 日韩黄在线观看| 中日韩美女免费视频网址在线观看| 亚洲一二在线观看| 久久久国产成人精品| 精品人伦一区二区三区蜜桃网站| 国产精品久久一区主播| 亚洲最新av在线网站| 亚洲国产精品电影在线观看| 亚洲91精品在线观看| 久久国产精品免费视频| 亚洲精品一区二区网址| 亚洲最新av在线| 91伊人影院在线播放| 国产日韩欧美中文| 91欧美精品成人综合在线观看| 国产精品高潮呻吟久久av黑人| 亚洲国产精品99久久| 国语自产精品视频在线看抢先版图片| 欧美日韩亚洲天堂| 欧美国产第一页| 中文字幕精品—区二区| 最近日韩中文字幕中文| 亚洲人成毛片在线播放| 国产午夜精品一区理论片飘花| 亚洲视频在线播放| 91国内免费在线视频| 欧美成人国产va精品日本一级| 国产精品成人一区| 成人xxxxx| 国产成人精品久久二区二区| 亚洲第一二三四五区| 在线中文字幕日韩| 97国产精品久久| 亚洲性视频网站| 国产精品一区二区性色av| 欧美性猛交99久久久久99按摩| 色老头一区二区三区在线观看| 国产成人91久久精品| 欧美激情18p| 日本精品视频网站| 亚洲色图50p| 高清日韩电视剧大全免费播放在线观看| 热99精品只有里视频精品| 亚洲福利视频免费观看| 欧美性xxxxxx| 日韩av在线电影网| 国产精品扒开腿爽爽爽视频| 欧美性猛交xxxx乱大交| 精品高清美女精品国产区| 中文字幕欧美视频在线| yw.139尤物在线精品视频| 一本一道久久a久久精品逆3p| 精品国内产的精品视频在线观看| 在线精品91av| 91免费视频网站| 国内精品小视频在线观看| 国产亚洲欧美日韩美女| www.亚洲一二| 国产精品扒开腿做爽爽爽视频| 成人乱人伦精品视频在线观看| 亚洲国产精品久久久久秋霞不卡| 日韩欧美福利视频| 午夜精品久久久久久99热软件| 日韩在线视频播放| 91理论片午午论夜理片久久| 午夜精品久久久久久久99热浪潮| 中文字幕日韩精品有码视频| 国产成人免费av电影| 91在线国产电影| 亚洲第一国产精品| 国产欧洲精品视频| 久久免费视频网站| 久久精品视频导航| 亚洲天堂一区二区三区| 日韩av中文在线| 日韩在线播放av| 韩曰欧美视频免费观看| 午夜精品免费视频| 91亚洲精品视频| 亚洲国产精品免费| 成人精品视频99在线观看免费| 欧美日韩亚洲精品内裤| 在线免费观看羞羞视频一区二区| 亚洲永久免费观看| 久久欧美在线电影| 久久久免费高清电视剧观看| 亚洲综合精品伊人久久| 国产成人综合久久| 欧美俄罗斯性视频| 亚洲国产精品福利| 国产成人精品av在线| 色婷婷综合久久久久| 亚洲成人在线网| 国产精品三级美女白浆呻吟| 久久久国产视频91| 大荫蒂欧美视频另类xxxx| 亚洲欧洲免费视频| 欧美在线免费看| 欧美一级在线播放| 亚洲国产欧美久久| 亚洲欧美一区二区精品久久久| 91免费国产网站| 国产日韩欧美中文| 日韩精品福利在线| 欧美日本精品在线| 亚洲欧美日韩天堂| 久久免费视频观看| 亚洲激情免费观看| 狠狠做深爱婷婷久久综合一区| 久久综合亚洲社区| 欧美激情一区二区三区成人| 亚洲一区二区三区在线免费观看| 黑人精品xxx一区| 在线视频免费一区二区| 亚洲午夜性刺激影院| 国产精品一区二区3区| 国产午夜精品全部视频播放| 欧美激情亚洲视频| 国产伊人精品在线| 最新亚洲国产精品| 日韩精品视频中文在线观看| 欧美精品一区在线播放| 日韩电影在线观看永久视频免费网站| 久久久久久com| 2019日本中文字幕| 亚洲欧美一区二区激情| 精品国产一区二区三区四区在线观看| 黑人巨大精品欧美一区免费视频| 影音先锋日韩有码| 欧美激情免费在线| www.久久色.com| 91日韩在线视频| 91性高湖久久久久久久久_久久99| 欧美成人免费全部观看天天性色| 精品国产一区二区三区久久狼黑人| 欧美日韩在线影院| 亚洲已满18点击进入在线看片| 久久久国产精品一区| 日av在线播放中文不卡| 在线色欧美三级视频| 精品国产电影一区| 中文字幕亚洲字幕| 亚洲一区精品电影| 久久视频在线视频| 国产精品天天狠天天看| 日本高清视频一区| 欧美xxxx18国产| 欧美成人激情图片网| 隔壁老王国产在线精品| 欧美日韩国产999| 精品国产一区二区三区四区在线观看| 亚洲在线观看视频网站| 日韩免费av在线|