91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

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

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

mysql出現死鎖的原因及解決方案

發布時間:2020-06-04 16:35:40 來源:網絡 閱讀:2026 作者:三月 欄目:MySQL數據庫
本文主要給大家介紹mysql出現死鎖的原因及解決方案,文章內容都是筆者用心摘選和編輯的,具有一定的針對性,對大家的參考意義還是比較大的,下面跟筆者一起了解下mysql出現死鎖的原因及解決方案吧。
  1. mysql都有什么鎖

MySQL有三種鎖的級別:頁級、表級、行級,內存級(latch)。

表級鎖:開銷小,加鎖快;不會出現死鎖;鎖定粒度大,發生鎖沖突的概率最高,并發度最低。

行級鎖:開銷大,加鎖慢;會出現死鎖;鎖定粒度最小,發生鎖沖突的概率最低,并發度也最高。

頁面鎖:開銷和加鎖時間界于表鎖和行鎖之間;會出現死鎖;鎖定粒度界于表鎖和行鎖之間,并發度一般

算法:

next KeyLocks鎖,同時鎖住記錄(數據),并且鎖住記錄前面的Gap

Gap鎖,不鎖記錄,僅僅記錄前面的Gap

Recordlock鎖(鎖數據,不鎖Gap)

所以其實 Next-KeyLocks=Gap鎖+ Recordlock鎖

  1. 什么情況下會造成死鎖

所謂死鎖 DeadLock 是指兩個或兩個以上的進程在執行過程中,
因爭奪資源而造成的一種互相等待的現象,若無外力作用,它們都將無法推進下去.
此時稱系統處于死鎖狀態或系統產生了死鎖,這些永遠在互相等竺的進程稱為死鎖進程.
表級鎖不會產生死鎖.所以解決死鎖主要還是針對于最常用的InnoDB.

死鎖的關鍵在于:兩個(或以上)的Session加鎖的順序不一致。

那么對應的解決死鎖問題的關鍵就是:讓不同的session加鎖有次序

4,下面就簡單來重現一下死鎖:

死鎖重現:
事務A:
root@test 16:01>select connection_id();
+-----------------+
| connection_id() |
+-----------------+
|           47274 |
+-----------------+
1 row in set (0.01 sec)

root@test 16:02>set autocommit =0;
Query OK, 0 rows affected (0.00 sec)

root@test 16:02>select * from t where id =1 for update;
+----+
| id |
+----+
|  1 |
+----+
1 row in set (0.00 sec)

root@test 16:02>select * from t where id =2 for update;
ERROR 1213 (40001): Deadlock found when trying to get lock; try restarting transaction
root@test 16:03>

事務B:
root@test 16:02>select connection_id();
+-----------------+
| connection_id() |
+-----------------+
|           47272 |
+-----------------+
1 row in set (0.00 sec)

root@test 16:02>set autocommit =0;
Query OK, 0 rows affected (0.00 sec)

root@test 16:02>select * from t where id =2 for update;
+----+
| id |
+----+
|  2 |
+----+
1 row in set (0.00 sec)

root@test 16:03>select * from t where id =1 for update;
+----+
| id |
+----+
|  1 |
+----+
1 row in set (5.53 sec)

===========================================

死鎖信息:

LATEST DETECTED DEADLOCK

2018-10-19 16:03:14 7f9612b6d700
(1) TRANSACTION:
TRANSACTION 870600, ACTIVE 11 sec starting index read
mysql tables in use 1, locked 1
LOCK WAIT 3 lock struct(s), heap size 360, 2 row lock(s)
MySQL thread id 47272, OS thread handle 0x7f9612e38700, query id 1112421 127.0.0.1 root statistics
select  from t where id =1 for update
** (1) WAITING FOR THIS LOCK TO BE GRANTED:
RECORD LOCKS space id 330 page no 3 n bits 72 index PRIMARY of table test.t trx id 870600 lock_mode X locks rec but not gap waiting
(2) TRANSACTION:
TRANSACTION 870599, ACTIVE 22 sec starting index read
mysql tables in use 1, locked 1
3 lock struct(s), heap size 360, 2 row lock(s)
MySQL thread id 47274, OS thread handle 0x7f9612b6d700, query id 1112422 127.0.0.1 root statistics
select * from t where id =2 for update
(2) HOLDS THE LOCK(S):
RECORD LOCKS space id 330 page no 3 n bits 72 index PRIMARY of table test.t trx id 870599 lock_mode X locks rec but not gap
(2) WAITING FOR THIS LOCK TO BE GRANTED:
RECORD LOCKS space id 330 page no 3 n bits 72 index PRIMARY of table test.t trx id 870599 lock_mode X locks rec but not gap waiting
*** WE ROLL BACK TRANSACTION (2)

5分析:
1,這上面是顯示是事務產生死鎖的sql并打印出相應所持和等待的鎖
2,上面的信息并沒有輸出事務死鎖之前的sql,所以可以直接堆出兩個事務執行的sql使他們相互持有了對方等待的鎖
3,造成死鎖是必然的,慢sql和不合理的業務的邏輯是造成死鎖過多的主要原因

重要的事情說三遍:優化sql,優化業務,優化邏輯

看完以上關于mysql出現死鎖的原因及解決方案,很多讀者朋友肯定多少有一定的了解,如需獲取更多的行業知識信息 ,可以持續關注我們的行業資訊欄目的。

向AI問一下細節

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

AI

福鼎市| 惠来县| 安平县| 融水| 滦平县| 株洲县| 西林县| 长沙市| 普宁市| 仙居县| 灵丘县| 蛟河市| 西乌| 武陟县| 昔阳县| 大竹县| 涟源市| 宾阳县| 炎陵县| 新巴尔虎左旗| 德化县| 张家港市| 林甸县| 西宁市| 磐石市| 金乡县| 左权县| 佛学| 大连市| 庄浪县| 卓资县| 乐亭县| 南康市| 大厂| 古蔺县| 陆良县| 腾冲县| 丰顺县| 望奎县| 永寿县| 长顺县|