mysql鎖和死結

來源:互聯網
上載者:User

著作權聲明:原創作品,允許轉載,轉載時請務必以超連結形式標明文章原始出版、作者資訊和本聲明。否則將追究法律責任。http://blog.csdn.net/mayongzhan - 馬永占,myz,mayongzhan

以下是一些總結.引用了一些網路上的經驗 MyISAM和MEMORY儲存引擎採用的是表級鎖table-level lockingBDB儲存引擎採用的是頁面鎖page-level locking,但也支援表級鎖InnoDB儲存引擎既支援行級鎖row-level locking,也支援表級鎖,但預設情況下是採用行級鎖 表級鎖 開銷小,加鎖快;不會出現死結;鎖定粒度大,發生鎖衝突的機率最高,並發度最低行級鎖 開銷大,加鎖慢;會出現死結;鎖定粒度最小,發生鎖衝突的機率最低,並發度也最高頁面鎖 開銷和加鎖時間界於表鎖和行鎖之間;會出現死結;鎖定粒度界於表鎖和行鎖之間,並發度一般 僅從鎖的角度來說:表級鎖更適合於以查詢為主,只有少量按索引條件更新資料的應用,如Web應用行級鎖則更適合於有大量按索引條件並發更新少量不同資料,同時又有並發查詢的應用,如一些線上交易處理系統 死結所謂死結<DeadLock>: 是指兩個或兩個以上的進程在執行過程中,因爭奪資源而造成的一種互相等待的現象,若無外力作用,它們都將無法推進下去.此時稱系統處於死結狀態或系統產生了死結,這些永遠在互相等竺的進程稱為死結進程. 表級鎖不會產生死結.所以解決死結主要還是真對於最常用的InnoDB. 在遇到問題時先執行show processlist找到死結線程號.然後Kill processNo 當然主要解決還是需要去看一下具體的操作.可能產生死結Show innodb status檢查引擎狀態 ,可以看到哪些語句產生死結 然後就是解決了.怎麼解決還是要看具體什麼問題.

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.