欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Mysql并發(fā)常見的死鎖及解決方法

 更新時(shí)間:2023年12月11日 15:26:31   作者:cwh_hot  
死鎖是在并發(fā)執(zhí)行的過程中,兩個(gè)或多個(gè)事務(wù)相互等待對方釋放資源的情況,本文主要介紹了Mysql并發(fā)常見的死鎖及解決方法,具有一定的參考價(jià)值,感興趣的可以了解一下

使用數(shù)據(jù)庫時(shí),有時(shí)會出現(xiàn)死鎖。對于實(shí)際應(yīng)用來說,就是出現(xiàn)系統(tǒng)卡頓。

死鎖是指兩個(gè)或兩個(gè)以上的事務(wù)在執(zhí)行過程中,因爭奪資源而造成的一種互相等待的現(xiàn)象。就是所謂的鎖資源請求產(chǎn)生了回路現(xiàn)象,即死循環(huán),此時(shí)稱系統(tǒng)處于死鎖狀態(tài)或系統(tǒng)產(chǎn)生了死鎖。常見的報(bào)錯(cuò)信息為“Deadlock found when trying to get lock...”。

上圖中,很明顯是右側(cè)的四輛汽車造成了死鎖。

死鎖發(fā)生以后,只有部分或完全回滾其中一個(gè)事務(wù),才能打破死鎖。多數(shù)情況下只需要重新執(zhí)行因死鎖回滾的事務(wù)即可。下面我們通過一個(gè)實(shí)例來了解死鎖是如何產(chǎn)生的。

例 1

為了方便讀者閱讀,操作之前我們先查詢 tb_student 表的數(shù)據(jù)和表結(jié)構(gòu)。

mysql> SELECT * FROM tb_student;
+----+------+------+------+------+
| id | name | age  | sex  | num  |
+----+------+------+------+------+
|  1 | 張三 |   31 | 男   |    4 |
|  2 | 李四 |   28 | 男   |    4 |
|  3 | 王五 |   13 | 女   |    4 |
|  4 | 張四 |   13 | 女   |    4 |
|  5 | 王四 |   15 | 男   |    4 |
|  6 | 趙六 |   12 | 女   |    4 |
+----+------+------+------+------+
6 rows in set (0.01 sec)

mysql> DESC tb_student;
+-------+-------------+------+-----+---------+----------------+
| Field | Type        | Null | Key | Default | Extra          |
+-------+-------------+------+-----+---------+----------------+
| id    | int(4)      | NO   | PRI | NULL    | auto_increment |
| name  | varchar(25) | NO   |     | NULL    |                |
| age   | int(11)     | YES  | MUL | NULL    |                |
| sex   | char(1)     | YES  |     | NULL    |                |
| num   | int(11)     | YES  |     | NULL    |                |
+-------+-------------+------+-----+---------+----------------+
5 rows in set (0.00 sec)

以下操作需要打開兩個(gè)會話窗口,即下面所提到的 A窗口和 B窗口。

在 A窗口中執(zhí)行以下命令:

mysql> BEGIN;
mysql> UPDATE tb_student SET num=5 WHERE age=13;
Query OK, 2 rows affected (0.04 sec)
Rows matched: 2  Changed: 2  Warnings: 0

緊接著在 B窗口中執(zhí)行以下命令。由于 age 是索引字段,與 A窗口中更新的是不同行的數(shù)據(jù),所以這時(shí)不會出現(xiàn)鎖等待現(xiàn)象。

mysql> BEGIN;
mysql> UPDATE tb_student SET num=8 WHERE age=15;
Query OK, 1 row affected (0.01 sec)
Rows matched: 1  Changed: 1  Warnings: 0

然后在 A窗口中,執(zhí)行以下命令,這時(shí)就會出現(xiàn)鎖等待現(xiàn)象了。

mysql> UPDATE tb_student SET num=10 WHERE age=15;

最后在 B窗口中,執(zhí)行以下命令,這時(shí)會出現(xiàn)相互等待資源的現(xiàn)象,也就是死鎖現(xiàn)象。

mysql> UPDATE tb_student SET num=12 WHERE age=13;
ERROR 1213 (40001): Deadlock found when trying to get lock; try restarting transaction

我們可以通過 SHOW ENGINE INNODB STATUS 命令查看死鎖的信息,運(yùn)行結(jié)果如下(這里只展示了部分信息):

LATEST DETECTED DEADLOCK
------------------------
2020-08-24 16:22:23 0x3944
*** (1) TRANSACTION:
TRANSACTION 22656, ACTIVE 108 sec starting index read
mysql tables in use 1, locked 1
LOCK WAIT 5 lock struct(s), heap size 1136, 6 row lock(s), undo log entries 2
MySQL thread id 33, OS thread handle 8808, query id 1689 localhost ::1 root updating
UPDATE tb_student SET num=10 WHERE age=15
*** (1) WAITING FOR THIS LOCK TO BE GRANTED:
RECORD LOCKS space id 197 page no 8 n bits 80 index index_age of table `test`.`tb_student` trx id 22656 lock_mode X waiting
Record lock, heap no 5 PHYSICAL RECORD: n_fields 2; compact format; info bits 0
0: len 4; hex 8000000f; asc     ;;
1: len 4; hex 80000005; asc     ;;
......

通過以上日志,我們就能確定造成死鎖的事務(wù)和 SQL 語句。

死鎖檢測

InnoDB 的并發(fā)寫操作會觸發(fā)死鎖,同時(shí) InnoDB 也提供了死鎖檢測機(jī)制。通過設(shè)置 innodb_deadlock_detect 參數(shù)的值來控制是否打開死鎖檢測。

  • innodb_deadlock_detect = ON :默認(rèn)值,打開死鎖檢測。數(shù)據(jù)庫發(fā)生死鎖時(shí),系統(tǒng)會自動回滾其中的某一個(gè)事務(wù),讓其它事務(wù)可以繼續(xù)執(zhí)行。
  • innodb_deadlock_detect = OFF:關(guān)閉死鎖檢測。發(fā)生死鎖時(shí),系統(tǒng)會用鎖等待來處理。

鎖等待是指在事務(wù)過程中產(chǎn)生的鎖,其它事務(wù)需要等待上一個(gè)事務(wù)釋放鎖,才能占用該資源。如果該事務(wù)一直不釋放,就需要持續(xù)等待下去,直到超過了鎖等待時(shí)間。當(dāng)超過鎖等待允許的最大時(shí)間,就會出現(xiàn)死鎖,然后當(dāng)前事務(wù)執(zhí)行失敗,自動執(zhí)行回滾操作。

MySQL 通過 innodb_lock_wait_timeout 參數(shù)控制鎖等待的時(shí)間,單位是秒。

mysql> SHOW VARIABLES LIKE '%innodb_lock_wait%';
+--------------------------+-------+
| Variable_name            | Value |
+--------------------------+-------+
| innodb_lock_wait_timeout | 120   |
+--------------------------+-------+
1 row in set, 1 warning (0.02 sec)

在實(shí)際應(yīng)用中,我們要盡量防止鎖等待現(xiàn)象的發(fā)生,下面介紹幾種避免死鎖的方法:

  • 如果不同程序會并發(fā)存取多個(gè)表,或者涉及多行記錄時(shí),盡量約定以相同的順序訪問表,這樣可以大大降低死鎖的發(fā)生。
  • 業(yè)務(wù)中要及時(shí)提交或者回滾事務(wù),可減少死鎖產(chǎn)生的概率。
  • 在同一個(gè)事務(wù)中,盡可能做到一次鎖定所需要的所有資源,減少死鎖產(chǎn)生概率。
  • 對于非常容易產(chǎn)生死鎖的業(yè)務(wù)部分,可以嘗試使用升級鎖粒度,通過表鎖定來減少死鎖產(chǎn)生的概率(表級鎖不會產(chǎn)生死鎖)。

到此這篇關(guān)于Mysql并發(fā)常見的死鎖及解決方法的文章就介紹到這了,更多相關(guān)Mysql并發(fā)死鎖內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • Mysql中undo、redo與binlog的區(qū)別淺析

    Mysql中undo、redo與binlog的區(qū)別淺析

    大家應(yīng)該都知道日志系統(tǒng)主要有redo log(重做日志)和binlog(歸檔日志),下面這篇文章主要給大家介紹了關(guān)于Mysql中undo、redo與binlog區(qū)別的相關(guān)資料,需要的朋友可以參考下
    2021-09-09
  • MySQL新手入門進(jìn)階語句匯總

    MySQL新手入門進(jìn)階語句匯總

    這篇文章主要給大家介紹了關(guān)于MySQL新手入門進(jìn)階語句的相關(guān)資料,總結(jié)分析了MySQL數(shù)據(jù)庫常用的查詢、條件查詢、排序、連接查詢、子查詢等相關(guān)操作技巧,文中通過圖文介紹的非常詳細(xì),需要的朋友可以參考下
    2022-09-09
  • mysql數(shù)據(jù)損壞,如何通過ibd和frm文件批量恢復(fù)數(shù)據(jù)庫數(shù)據(jù)

    mysql數(shù)據(jù)損壞,如何通過ibd和frm文件批量恢復(fù)數(shù)據(jù)庫數(shù)據(jù)

    這篇文章主要介紹了mysql數(shù)據(jù)損壞,如何通過ibd和frm文件批量恢復(fù)數(shù)據(jù)庫數(shù)據(jù)問題,具有很好的參考價(jià)值,希望對大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2023-08-08
  • MySQL的時(shí)間差函數(shù)TIMESTAMPDIFF、DATEDIFF的用法

    MySQL的時(shí)間差函數(shù)TIMESTAMPDIFF、DATEDIFF的用法

    這篇文章主要介紹了MySQL的時(shí)間差函數(shù)TIMESTAMPDIFF、DATEDIFF的用法,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2019-12-12
  • MySQL兩個(gè)字段模糊匹配操作方案

    MySQL兩個(gè)字段模糊匹配操作方案

    這篇文章主要給大家介紹了關(guān)于MySQL兩個(gè)字段模糊匹配操作的相關(guān)資料,兩張MySQL表進(jìn)行模糊匹配可以使用like語法來實(shí)現(xiàn),文中通過代碼介紹的非常詳細(xì),需要的朋友可以參考下
    2023-09-09
  • CentOS7.x?安裝mysql5.7?XtraBackUp備份工具使用命令詳解

    CentOS7.x?安裝mysql5.7?XtraBackUp備份工具使用命令詳解

    這篇文章主要介紹了CentOS7.x?安裝mysql5.7?XtraBackUp備份工具使用,本文給大家介紹了mysql安裝過程及命令使用方法,需要的朋友可以參考下
    2022-04-04
  • mysql如何顯示longblob解決方案

    mysql如何顯示longblob解決方案

    這篇文章主要為大家介紹了mysql如何顯示longblob解決方案,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2023-10-10
  • mysql利用覆蓋索引避免回表優(yōu)化查詢

    mysql利用覆蓋索引避免回表優(yōu)化查詢

    這篇文章主要給大家介紹了關(guān)于mysql如何利用覆蓋索引避免回表優(yōu)化查詢的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2021-02-02
  • MySQL 不允許從遠(yuǎn)程訪問的解決方法

    MySQL 不允許從遠(yuǎn)程訪問的解決方法

    MySQL 不允許從遠(yuǎn)程訪問的原因有很多除了下面的方法,還有需要看服務(wù)器安全設(shè)置禁止訪問本機(jī)的3306端口。
    2010-03-03
  • mybatis-plus分頁傳入?yún)?shù)后sql where條件沒有l(wèi)imit分頁信息操作

    mybatis-plus分頁傳入?yún)?shù)后sql where條件沒有l(wèi)imit分頁信息操作

    這篇文章主要介紹了mybatis-plus分頁傳入?yún)?shù)后sql where條件沒有l(wèi)imit分頁信息操作,具有很好的參考價(jià)值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2020-11-11

最新評論