您好,登錄后才能下訂單哦!
這篇文章給大家介紹MySQL中怎么查看死鎖日志,內容非常詳細,感興趣的小伙伴們可以參考借鑒,希望對大家能有所幫助。
MySQL查看死鎖日志
show engine innodb status
所謂死鎖<DeadLock>: 是指兩個或兩個以上的進程在執(zhí)行過程中, 因爭奪資源而造成的一種互相等待的現(xiàn)象,若無外力作用,它們都將無法推進下去. 此時稱系統(tǒng)處于死鎖狀態(tài)或系統(tǒng)產生了死鎖,這些永遠在互相等竺的進程稱為死鎖進程. 表級鎖不會產生死鎖.所以解決死鎖主要還是針對于最常用的InnoDB.
例如(以下會話id為主鍵):
mysql> select * from t3 where id=9 for update; +----+--------+------+---------------------+ | id | course | name | ctime | +----+--------+------+---------------------+ | 9 | JX | f | 2016-03-01 11:36:30 | +----+--------+------+---------------------+ row in set (0.00 sec)
Session2:
mysql> select * from t3 where id<20 for update; ## 鎖等待中
Session1:
mysql> insert into t3 values(7,'ae','a',now()); ERROR 1213 (40001): Deadlock found when trying to get lock; try restarting transaction
Session2在等待Session1的id=9的鎖,session2又持了1到8的鎖(注意9到19的范圍并沒有被session2鎖?。?,最后,session1在插入新行時又得等待session2,故死鎖發(fā)生了。
關于MySQL中怎么查看死鎖日志就分享到這里了,希望以上內容可以對大家有一定的幫助,可以學到更多知識。如果覺得文章不錯,可以把它分享出去讓更多的人看到。
免責聲明:本站發(fā)布的內容(圖片、視頻和文字)以原創(chuàng)、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯(lián)系站長郵箱:is@yisu.com進行舉報,并提供相關證據(jù),一經查實,將立刻刪除涉嫌侵權內容。