<span id="mktg5"></span>

<i id="mktg5"><meter id="mktg5"></meter></i>

        <label id="mktg5"><meter id="mktg5"></meter></label>
        最新文章專題視頻專題問答1問答10問答100問答1000問答2000關鍵字專題1關鍵字專題50關鍵字專題500關鍵字專題1500TAG最新視頻文章推薦1 推薦3 推薦5 推薦7 推薦9 推薦11 推薦13 推薦15 推薦17 推薦19 推薦21 推薦23 推薦25 推薦27 推薦29 推薦31 推薦33 推薦35 推薦37視頻文章20視頻文章30視頻文章40視頻文章50視頻文章60 視頻文章70視頻文章80視頻文章90視頻文章100視頻文章120視頻文章140 視頻2關鍵字專題關鍵字專題tag2tag3文章專題文章專題2文章索引1文章索引2文章索引3文章索引4文章索引5123456789101112131415文章專題3
        問答文章1 問答文章501 問答文章1001 問答文章1501 問答文章2001 問答文章2501 問答文章3001 問答文章3501 問答文章4001 問答文章4501 問答文章5001 問答文章5501 問答文章6001 問答文章6501 問答文章7001 問答文章7501 問答文章8001 問答文章8501 問答文章9001 問答文章9501
        當前位置: 首頁 - 科技 - 知識百科 - 正文

        mysql數據庫死鎖原因及解決辦法_MySQL

        來源:懂視網 責編:小采 時間:2020-11-09 20:15:08
        文檔

        mysql數據庫死鎖原因及解決辦法_MySQL

        mysql數據庫死鎖原因及解決辦法_MySQL:死鎖(Deadlock) 所謂死鎖:是指兩個或兩個以上的進程在執行過程中,因爭奪資源而造成的一種互相等待的現象,若無外力作用,它們都將無法推進下去。此時稱系統處于死鎖狀態或系統產生了死鎖,這些永遠在互相等待的進程稱為死鎖進程。由于資源占用是互斥的,
        推薦度:
        導讀mysql數據庫死鎖原因及解決辦法_MySQL:死鎖(Deadlock) 所謂死鎖:是指兩個或兩個以上的進程在執行過程中,因爭奪資源而造成的一種互相等待的現象,若無外力作用,它們都將無法推進下去。此時稱系統處于死鎖狀態或系統產生了死鎖,這些永遠在互相等待的進程稱為死鎖進程。由于資源占用是互斥的,

        死鎖(Deadlock)

        所謂死鎖:是指兩個或兩個以上的進程在執行過程中,因爭奪資源而造成的一種互相等待的現象,若無外力作用,它們都將無法推進下去。此時稱系統處于死鎖狀態或系統產生了死鎖,這些永遠在互相等待的進程稱為死鎖進程。由于資源占用是互斥的,當某個進程提出申請資源后,使得有關進程在無外力協助下,永遠分配不到必需的資源而無法繼續運行,這就產生了一種特殊現象死鎖。 一種情形,此時執行程序中兩個或多個線程發生永久堵塞(等待),每個線程都在等待被其他線程占用并堵塞了的資源。例如,如果線程A鎖住了記錄1并等待記錄2,而線程B鎖住了記錄2并等待記錄1,這樣兩個線程就發生了死鎖現象。計算機系統中,如果系統的資源分配策略不當,更常見的可能是程序員寫的程序有錯誤等,則會導致進程因競爭資源不當而產生死鎖的現象。鎖有多種實現方式,比如意向鎖,共享-排他鎖,鎖表,樹形協議,時間戳協議等等。鎖還有多種粒度,比如可以在表上加鎖,也可以在記錄上加鎖。

        產生死鎖的原因主要是:

        (1)系統資源不足。
        (2) 進程運行推進的順序不合適。
        (3)資源分配不當等。

        如果系統資源充足,進程的資源請求都能夠得到滿足,死鎖出現的可能性就很低,否則就會因爭奪有限的資源而陷入死鎖。其次,進程運行推進順序與速度不同,也可能產生死鎖。

        產生死鎖的四個必要條件:

        (1) 互斥條件:一個資源每次只能被一個進程使用。
        (2) 請求與保持條件:一個進程因請求資源而阻塞時,對已獲得的資源保持不放。
        (3) 不剝奪條件:進程已獲得的資源,在末使用完之前,不能強行剝奪。
        (4) 循環等待條件:若干進程之間形成一種頭尾相接的循環等待資源關系。

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

        死鎖的預防和解除:

        理解了死鎖的原因,尤其是產生死鎖的四個必要條件,就可以最大可能地避免、預防和解除死鎖。所以,在系統設計、進程調度等方面注意如何不讓這四個必要條件成立,如何確定資源的合理分配算法,避免進程永久占據系統資源。此外,也要防止進程在處于等待狀態的情況下占用資源,在系統運行過程中,對進程發出的每一個系統能夠滿足的資源申請進行動態檢查,并根據檢查結果決定是否分配資源,若分配后系統可能發生死鎖,則不予分配,否則予以分配 。因此,對資源的分配要給予合理的規劃。
        如何將死鎖減至最少


        雖然不能完全避免死鎖,但可以使死鎖的數量減至最少。將死鎖減至最少可以增加事務的吞吐量并減少系統開銷,因為只有很少的事務回滾,而回滾會取消事務執行的所有工作。由于死鎖時回滾而由應用程序重新提交。

        下列方法有助于最大限度地降低死鎖:

        (1)按同一順序訪問對象。
        (2)避免事務中的用戶交互。
        (3)保持事務簡短并在一個批處理中。
        (4)使用低隔離級別。
        (5)使用綁定連接。

        按同一順序訪問對象

        如果所有并發事務按同一順序訪問對象,則發生死鎖的可能性會降低。例如,如果兩個并發事務獲得 Supplier 表上的鎖,然后獲得 Part 表上的鎖,則在其中一個事務完成之前,另一個事務被阻塞在 Supplier 表上。第一個事務提交或回滾后,第二個事務繼續進行。不發生死鎖。將存儲過程用于所有的數據修改可以標準化訪問對象的順序。

        避免事務中的用戶交互

        避免編寫包含用戶交互的事務,因為運行沒有用戶交互的批處理的速度要遠遠快于用戶手動響應查詢的速度,例如答復應用程序請求參數的提示。例如,如果事務正在等待用戶輸入,而用戶去吃午餐了或者甚至回家過周末了,則用戶將此事務掛起使之不能完成。這樣將降低系統的吞吐量,因為事務持有的任何鎖只有在事務提交或回滾時才會釋放。即使不出現死鎖的情況,訪問同一資源的其它事務也會被阻塞,等待該事務完成。

        保持事務簡短并在一個批處理中

        在同一數據庫中并發執行多個需要長時間運行的事務時通常發生死鎖。事務運行時間越長,其持有排它鎖或更新鎖的時間也就越長,從而堵塞了其它活動并可能導致死鎖。

        保持事務在一個批處理中,可以最小化事務的網絡通信往返量,減少完成事務可能的延遲并釋放鎖。

        使用低隔離級別

        確定事務是否能在更低的隔離級別上運行。執行提交讀允許事務讀取另一個事務已讀取(未修改)的數據,而不必等待第一個事務完成。使用較低的隔離級別(例如提交讀)而不使用較高的隔離級別(例如可串行讀)可以縮短持有共享鎖的時間,從而降低了鎖定爭奪。

        使用綁定連接

        使用綁定連接使同一應用程序所打開的兩個或多個連接可以相互合作。次級連接所獲得的任何鎖可以象由主連接獲得的鎖那樣持有,反之亦然,因此不會相互阻塞。

        聲明:本網頁內容旨在傳播知識,若有侵權等問題請及時與本網聯系,我們將在第一時間刪除處理。TEL:177 7030 7066 E-MAIL:11247931@qq.com

        文檔

        mysql數據庫死鎖原因及解決辦法_MySQL

        mysql數據庫死鎖原因及解決辦法_MySQL:死鎖(Deadlock) 所謂死鎖:是指兩個或兩個以上的進程在執行過程中,因爭奪資源而造成的一種互相等待的現象,若無外力作用,它們都將無法推進下去。此時稱系統處于死鎖狀態或系統產生了死鎖,這些永遠在互相等待的進程稱為死鎖進程。由于資源占用是互斥的,
        推薦度:
        • 熱門焦點

        最新推薦

        猜你喜歡

        熱門推薦

        專題
        Top
        主站蜘蛛池模板: 亚洲成a人片77777老司机| 久久这里只精品热免费99| 欧美大尺寸SUV免费| 亚洲精品免费在线视频| 久操免费在线观看| 亚洲AV第一页国产精品| 免费国产黄网站在线观看可以下载 | 国产自国产自愉自愉免费24区| 在线观看亚洲精品福利片| 国产精品永久免费视频| 亚洲精品乱码久久久久久自慰 | 免费成人高清在线视频| 无码乱人伦一区二区亚洲| 亚洲精品视频免费看| 麻豆狠色伊人亚洲综合网站| 处破痛哭A√18成年片免费| 亚洲爆乳无码专区www| jjzz亚洲亚洲女人| 福利免费在线观看| 亚洲激情校园春色| 免费无码黄动漫在线观看| 污污污视频在线免费观看| 亚洲熟妇无码AV在线播放| 99久久久国产精品免费牛牛四川 | 免费视频精品一区二区| 亚洲欧洲日产国码无码久久99| 日日麻批免费40分钟无码| 国产成人亚洲综合一区| 亚洲成av人片在线观看天堂无码 | 亚洲人成伊人成综合网久久| 日韩激情淫片免费看| 男女拍拍拍免费视频网站| 亚洲免费在线视频播放| 亚洲av日韩av欧v在线天堂| 国产精成人品日日拍夜夜免费| 日韩亚洲国产高清免费视频| 亚洲成年看片在线观看| 69视频在线是免费观看| 瑟瑟网站免费网站入口| 亚洲黄色网址在线观看| 亚洲国产精品丝袜在线观看|