麻豆小视频在线观看_中文黄色一级片_久久久成人精品_成片免费观看视频大全_午夜精品久久久久久久99热浪潮_成人一区二区三区四区

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

數據庫死鎖產生的原因及處理方案有哪些

2024-09-07 22:12:51
字體:
來源:轉載
供稿:網友
  數據庫死鎖產生的原因及解決方案有哪些?很多新手對此不是很清楚,為了幫助大家解決這個難題,下面小編將為大家詳細講解,有這方面需求的人可以來學習下,希望你能有所收獲。
 
  數據庫死鎖產生的原因及解決方案:1、程序的BUG產生,需要調整的程序的邏輯;2、頁面的按鈕沒有立即生效,需要使用樂觀鎖、悲觀鎖進行控制;3、執行多個不滿足條件的update語句;需要對語句進行分析,建立相應的索引進行優化。
 
  數據庫死鎖產生的原因及解決方案:
 
  在數據庫中有兩種基本的鎖類型:排它鎖(Exclusive Locks,即X鎖)和共享鎖(Share Locks,即S鎖)。當數據對象被加上排它鎖時,其他的事務不能對它讀取和修改。加了共享鎖的數據對象可以被其他事務讀取,但不能修改。數據庫利用這兩 種基本的鎖類型來對數據庫的事務進行并發控制。
 
  死鎖的第一種情況
 
  一個用戶A 訪問表A(鎖住了表A),然后又訪問表B;另一個用戶B 訪問表B(鎖住了表B),然后企圖訪問表A;這時用戶A由于用戶B已經鎖住表B,它必須等待用戶B釋放表B才能繼續,同樣用戶B要等用戶A釋放表A才能繼續,這就死鎖就產生了。
 
  解決方法:
 
  這種死鎖比較常見,是由于程序的BUG產生的,除了調整的程序的邏輯沒有其它的辦法。仔細分析程序的邏輯,對于數據庫的多表操作時,盡量按照相同的順序進 行處理,盡量避免同時鎖定兩個資源,如操作A和B兩張表時,總是按先A后B的順序處理, 必須同時鎖定兩個資源時,要保證在任何時刻都應該按照相同的順序來鎖定資源。
 
  死鎖的第二種情況
 
  用戶A查詢一條紀錄,然后修改該條紀錄;這時用戶B修改該條紀錄,這時用戶A的事務里鎖的性質由查詢的共享鎖企圖上升到獨占鎖,而用戶B里的獨占鎖由于A 有共享鎖存在所以必須等A釋放掉共享鎖,而A由于B的獨占鎖而無法上升的獨占鎖也就不可能釋放共享鎖,于是出現了死鎖。這種死鎖比較隱蔽,但在稍大點的項 目中經常發生。如在某項目中,頁面上的按鈕點擊后,沒有使按鈕立刻失效,使得用戶會多次快速點擊同一按鈕,這樣同一段代碼對數據庫同一條記錄進行多次操 作,很容易就出現這種死鎖的情況。
 
  解決方法:
 
  1、對于按鈕等控件,點擊后使其立刻失效,不讓用戶重復點擊,避免對同時對同一條記錄操作。
 
  2、使用樂觀鎖進行控制。樂觀鎖大多是基于數據版本(Version)記錄機制實現。即為數據增加一個版本標識,在基于數據庫表的版本解決方案中,一般是 通過為數據庫表增加一個“version”字段來實現。讀取出數據時,將此版本號一同讀出,之后更新時,對此版本號加一。此時,將提交數據的版本數據與數 據庫表對應記錄的當前版本信息進行比對,如果提交的數據版本號大于數據庫表當前版本號,則予以更新,否則認為是過期數據。樂觀鎖機制避免了長事務中的數據 庫加鎖開銷(用戶A和用戶B操作過程中,都沒有對數據庫數據加鎖),大大提升了大并發量下的系統整體性能表現。Hibernate 在其數據訪問引擎中內置了樂觀鎖實現。需要注意的是,由于樂觀鎖機制是在我們的系統中實現,來自外部系統的用戶更新操作不受我們系統的控制,因此可能會造 成臟數據被更新到數據庫中。
 
  3、使用悲觀鎖進行控制。悲觀鎖大多數情況下依靠數據庫的鎖機制實現,如Oracle的Select … for update語句,以保證操作最大程度的獨占性。但隨之而來的就是數據庫性能的大量開銷,特別是對長事務而言,這樣的開銷往往無法承受。如一個金融系統, 當某個操作員讀取用戶的數據,并在讀出的用戶數據的基礎上進行修改時(如更改用戶賬戶余額),如果采用悲觀鎖機制,也就意味著整個操作過程中(從操作員讀 出數據、開始修改直至提交修改結果的全過程,甚至還包括操作員中途去煮咖啡的時間),數據庫記錄始終處于加鎖狀態,可以想見,如果面對成百上千個并發,這 樣的情況將導致災難性的后果。所以,采用悲觀鎖進行控制時一定要考慮清楚。
 
  死鎖的第三種情況
 
  如果在事務中執行了一條不滿足條件的update語句,則執行全表掃描,把行級鎖上升為表級鎖,多個這樣的事務執行后,就很容易產生死鎖和阻塞。類似的情 況還有當表中的數據量非常龐大而索引建的過少或不合適的時候,使得經常發生全表掃描,最終應用系統會越來越慢,最終發生阻塞或死鎖。
 
  解決方法:
 
  SQL語句中不要使用太復雜的關聯多表的查詢;使用“執行計劃”對SQL語句進行分析,對于有全表掃描的SQL語句,建立相應的索引進行優化。
  
  看完上述內容是否對您有幫助呢?

(編輯:武林網)

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 精品亚洲夜色av98在线观看 | 精品国产一区二区三区四区在线 | 成人视屏网站 | 一级电影在线观看 | 午夜精品小视频 | 欧美成在人线a免费 | 欧美成人一区二区视频 | 97久色| 亚洲精品欧美二区三区中文字幕 | 免费国产成人高清在线看软件 | 中文字幕在线播放视频 | 午夜精品福利视频 | 天天干天天透 | 欧美高清一级片 | 欧美 日本 在线 | 国产精品视频不卡 | 久久国产精品电影 | 欧美黄色一级片在线观看 | 中国国语毛片免费观看视频 | 日韩视频一区在线 | 欧美在线 | 亚洲 | 草久影视| lutube成人福利在线观看污 | www.91在线| 久久久久一区二区三区 | 俄罗斯16一20sex牲色另类 | 亚洲一区二区三区日本久久九 | 欧美黄 片免费观看 | 成人福利在线播放 | 久草视频手机在线观看 | 国产日韩在线观看一区 | www.99久久久 | 色综合视频网 | 国产日本在线 | 视频一区 中文字幕 | 精品中文字幕视频 | 久久久一区二区精品 | 日韩一级精品 | 色网站综合 | 久久精品国产99久久久古代 | 中文字幕亚洲视频 |