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

溫馨提示×

溫馨提示×

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

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

mysql處理死鎖問題的方法

發布時間:2020-09-08 09:25:28 來源:億速云 閱讀:185 作者:小新 欄目:編程語言

小編給大家分享一下mysql處理死鎖問題的方法,希望大家閱讀完這篇文章后大所收獲,下面讓我們一起去探討吧!

MySQL有兩種死鎖處理方式:

1、等待,直到超時(innodb_lock_wait_timeout=50s);

2、發起死鎖檢測,主動回滾一條事務,讓其他事務繼續執行(innodb_deadlock_detect=on);

由于性能原因,一般都是使用死鎖檢測來進行處理死鎖。

死鎖檢測

死鎖檢測的原理是構建一個以事務為頂點、鎖為邊的有向圖,判斷有向圖是否存在環,存在即有死鎖。

回滾

檢測到死鎖之后,選擇插入更新或者刪除的行數最少的事務回滾,基于 INFORMATION_SCHEMA.INNODB_TRX 表中的 trx_weight 字段來判斷。

如何避免發生死鎖?

一、收集死鎖信息:

利用命令 SHOW ENGINE INNODB STATUS查看死鎖原因。

調試階段開啟 innodb_print_all_deadlocks,收集所有死鎖日志。

二、減少死鎖:

使用事務,不使用 lock tables 。

保證沒有長事務。

操作完之后立即提交事務,特別是在交互式命令行中。

如果在用 (SELECT ... FOR UPDATE or SELECT ... LOCK IN SHARE MODE),嘗試降低隔離級別。

修改多個表或者多個行的時候,將修改的順序保持一致。

創建索引,可以使創建的鎖更少。

最好不要用 (SELECT ... FOR UPDATE or SELECT ... LOCK IN SHARE MODE)。

如果上述都無法解決問題,那么嘗試使用 lock tables t1, t2, t3 鎖多張表。

看完了這篇文章,相信你對mysql處理死鎖問題的方法有了一定的了解,想了解更多相關知識,歡迎關注億速云行業資訊頻道,感謝各位的閱讀!

向AI問一下細節

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

AI

吉林省| 铜鼓县| 蓝田县| 云南省| 萨嘎县| 昔阳县| 海兴县| 海淀区| 溆浦县| 青岛市| 彰化市| 固始县| 顺义区| 乳山市| 文山县| 土默特左旗| 文水县| 鱼台县| 克山县| 高青县| 贵港市| 玛多县| 交口县| 呼和浩特市| 乐平市| 龙岩市| 晋江市| 英山县| 上饶市| 株洲县| 桐庐县| 景宁| 延吉市| 仪陇县| 汉中市| 唐海县| 南投县| 岗巴县| 石首市| 大石桥市| 樟树市|