溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

MySQL中怎么查看死鎖日志

發(fā)布時間:2021-06-15 14:06:26 來源:億速云 閱讀:1288 作者:Leah 欄目:大數(shù)據(jù)

這篇文章給大家介紹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中怎么查看死鎖日志就分享到這里了,希望以上內容可以對大家有一定的幫助,可以學到更多知識。如果覺得文章不錯,可以把它分享出去讓更多的人看到。

向AI問一下細節(jié)

免責聲明:本站發(fā)布的內容(圖片、視頻和文字)以原創(chuàng)、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯(lián)系站長郵箱:is@yisu.com進行舉報,并提供相關證據(jù),一經查實,將立刻刪除涉嫌侵權內容。

AI