MySQL系列之十 MySQL事務(wù)隔離實(shí)現(xiàn)并發(fā)控制
一、并發(fā)訪(fǎng)問(wèn)控制
實(shí)現(xiàn)的并發(fā)訪(fǎng)問(wèn)的控制技術(shù)是基于鎖;
鎖分為表級(jí)鎖和行級(jí)鎖,MyISAM存儲(chǔ)引擎不支持行級(jí)鎖;InnoDB支持表級(jí)鎖和行級(jí)鎖;
鎖的分類(lèi)有讀鎖和寫(xiě)鎖,讀鎖也被稱(chēng)為共享鎖,加讀鎖的時(shí)候其他的人可以讀;寫(xiě)鎖也稱(chēng)為獨(dú)占鎖或排它鎖,一個(gè)寫(xiě)鎖會(huì)阻塞其他讀操作和寫(xiě)操作;
鎖還分為隱式鎖和顯式鎖,隱式鎖由存儲(chǔ)引擎自行管理,顯式鎖是用戶(hù)手動(dòng)添加鎖;
鎖策略:在鎖粒度及數(shù)據(jù)安全性尋求的平衡機(jī)制。
顯式鎖的使用方法:LOCK TABLES tbl_name READ|WRITE
MariaDB [school]> LOCK TABLES students READ; #加讀鎖
MariaDB [school]> UNLOCK TABLES; #解鎖
讀鎖:任何人都不可寫(xiě)
寫(xiě)鎖:自己可以讀寫(xiě),但是其他人不可讀寫(xiě)
FLUSH TABLES tb_name :關(guān)閉正在打開(kāi)的表(清除查詢(xún)緩存),通常在備份前加全局讀鎖
SELECT clause [FOR UPDATE | LOCK IN SHARE MODE] 查詢(xún)時(shí)加寫(xiě)或讀鎖
二、事務(wù)Transactions
一組原子性的SQL語(yǔ)句,或一個(gè)獨(dú)立工作單元
1、事務(wù)遵循ACID原則:
- A:atomicity原子性;整個(gè)事務(wù)中的所有操作要么全部成功執(zhí)行,要么全部失敗后回滾
- C:consistency一致性;數(shù)據(jù)庫(kù)總是從一個(gè)一致性狀態(tài)轉(zhuǎn)換為另一個(gè)一致性狀態(tài)
- I:Isolation隔離性;一個(gè)事務(wù)所做出的操作在提交之前,是不能為其它事務(wù)所見(jiàn);隔離有多種隔離級(jí)別,實(shí)現(xiàn)并發(fā)
- D:durability持久性;一旦事務(wù)提交,其所做的修改會(huì)永久保存于數(shù)據(jù)庫(kù)中
2、事務(wù)的生命周期
顯式事務(wù):明確的規(guī)定事務(wù)的開(kāi)始
隱式事務(wù):默認(rèn)為隱式事務(wù),每執(zhí)行完一句語(yǔ)句后直接提交
autocommit = {OFF|ON} 開(kāi)啟或關(guān)閉自動(dòng)提交,建議使用顯式請(qǐng)求和提交事務(wù),而不要使用“自動(dòng)提交”功能
啟動(dòng)事務(wù):START TRANSACTION;
插入標(biāo)簽:ROLLBACK TO ##;
撤銷(xiāo)回指定標(biāo)簽:ROLLBACK TO ##;
全部撤銷(xiāo):ROLLBACK;
提交事務(wù):COMMIT;
刪除標(biāo)簽:RELEASE SAVEPOINT;
MariaDB [school]> START TRANSACTION; #明確指明啟動(dòng)一個(gè)事務(wù) MariaDB [school]> INSERT students(StuID,Name,Age,Gender) VALUES (26,'Tom',22,'M'); #添加一條記錄 MariaDB [school]> SAVEPOINT sp26; #插入一個(gè)標(biāo)簽 MariaDB [school]> INSERT students(StuID,Name,Age,Gender) VALUES (27,'Maria',12,'F'); #再加入一條記錄 MariaDB [school]> SELECT * FROM students WHERE stuid IN (26,27); #查看一下,可以看到剛剛插入的數(shù)據(jù) +-------+-------+-----+--------+---------+-----------+ | StuID | Name | Age | Gender | ClassID | TeacherID | +-------+-------+-----+--------+---------+-----------+ | 26 | Tom | 22 | M | NULL | NULL | | 27 | Maria | 12 | F | NULL | NULL | +-------+-------+-----+--------+---------+-----------+ MariaDB [school]> ROLLBACK TO sp26; #撤銷(xiāo)到sp26標(biāo)簽之前的狀態(tài) MariaDB [school]> SELECT * FROM students WHERE stuid IN (26,27); #查看一下,剛剛maria的信息被撤回了 +-------+------+-----+--------+---------+-----------+ | StuID | Name | Age | Gender | ClassID | TeacherID | +-------+------+-----+--------+---------+-----------+ | 26 | Tom | 22 | M | NULL | NULL | +-------+------+-----+--------+---------+-----------+ MariaDB [school]> COMMIT; #提交事務(wù) MariaDB [school]> SELECT * FROM students WHERE stuid IN (26,27); #最終的數(shù)據(jù) +-------+------+-----+--------+---------+-----------+ | StuID | Name | Age | Gender | ClassID | TeacherID | +-------+------+-----+--------+---------+-----------+ | 26 | Tom | 22 | M | NULL | NULL | +-------+------+-----+--------+---------+-----------+
3、事務(wù)的隔離級(jí)別
- READ UNCOMMITTED 其他事務(wù)可以看到未提交的臟數(shù)據(jù),產(chǎn)生臟讀
- READ COMMITTED 提交后其他事務(wù)可以看到修改后的數(shù)據(jù),每次讀取的數(shù)據(jù)可能不一致,不可重復(fù)讀
- REPEATABLE READ 可重復(fù)讀,每次看到的數(shù)據(jù)都一致,數(shù)據(jù)被修改后看不到最新數(shù)據(jù),會(huì)產(chǎn)生幻讀(默認(rèn)設(shè)置)
- SETIALIZABILE 未提交的讀事務(wù)阻塞修改事務(wù),串行執(zhí)行,并發(fā)性差
MVCC: 多版本并發(fā)控制,和事務(wù)級(jí)別相關(guān)
修改事務(wù)隔離級(jí)別:服務(wù)器變量tx_isolation指定,默認(rèn)為REPEATABLE-READ,可在GLOBAL和SESSION級(jí)進(jìn)行設(shè)置
tx_isolation
- Description: The transaction isolation level. See also SET TRANSACTION ISOLATION LEVEL.
- Commandline:
--transaction-isolation=name
- Scope: Global, Session
- Dynamic: Yes
- Type: enumeration
- Default Value:
REPEATABLE-READ
- Valid Values:
READ-UNCOMMITTED
,READ-COMMITTED
,REPEATABLE-READ
,SERIALIZABLE
MariaDB [school]> SELECT @@tx_isolation; #默認(rèn)為可重復(fù)讀級(jí)別 +-----------------+ | @@tx_isolation | +-----------------+ | REPEATABLE-READ | +-----------------+ MariaDB [school]> SET tx_isolation='READ-UNCOMMITTED'; MariaDB [school]> set tx_isolation='READ-COMMITTED'; MariaDB [school]> set tx_isolation='REPEATABLE-READ'; MariaDB [school]> set tx_isolation='SERIALIZABLE';
4、死鎖
兩個(gè)或多個(gè)事務(wù)在同一資源相互占用,并請(qǐng)求鎖定對(duì)方占用的資源的狀態(tài)會(huì)發(fā)生死鎖
在A事務(wù)修改t1表的第3行,B事務(wù)修改t2表的第2行時(shí);這時(shí)A事務(wù)去修改t2表的第2行,這時(shí)就把A事務(wù)阻塞了,然后B事務(wù)有剛剛好去修改t1表的第3行,這時(shí)B事務(wù)也被阻塞了,這時(shí)就產(chǎn)生了死鎖。
倆個(gè)事務(wù)同時(shí)去更改對(duì)方的修改的表,互相阻塞;系統(tǒng)會(huì)發(fā)現(xiàn)死鎖,會(huì)自動(dòng)犧牲一個(gè)代價(jià)小的事務(wù)來(lái)解開(kāi)死鎖。
ERROR 1213 (40001): Deadlock found when trying to get lock; try restarting transaction
查看進(jìn)程列表:MariaDB [school]> SHOW PROCESSLIST;
殺死進(jìn)程:MariaDB [school]> KILL 5;
到此這篇關(guān)于MySQL系列之十 MySQL事務(wù)隔離實(shí)現(xiàn)并發(fā)控制的文章就介紹到這了,更多相關(guān)mysql并發(fā)控制內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
到此這篇關(guān)于MySQL系列之十 MySQL事務(wù)隔離實(shí)現(xiàn)并發(fā)控制的文章就介紹到這了,更多相關(guān)mysql并發(fā)控制內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
MYSQL5 masterslave數(shù)據(jù)同步配置方法
因線(xiàn)路或安全需要我們不得不考慮mysql的備份,特把mysql數(shù)據(jù)備份的方法整理下。2008-09-09mysql使用GROUP BY分組實(shí)現(xiàn)取前N條記錄的方法
這篇文章主要介紹了mysql使用GROUP BY分組實(shí)現(xiàn)取前N條記錄的方法,結(jié)合實(shí)例形式較為詳細(xì)的分析了mysql中GROUP BY分組的相關(guān)使用技巧,需要的朋友可以參考下2016-06-06InnoDB數(shù)據(jù)庫(kù)死鎖問(wèn)題處理
本文給大家講解的是mysql數(shù)據(jù)庫(kù)InnoDB類(lèi)型,在update表的時(shí)候出現(xiàn)死鎖現(xiàn)象的原因及解決辦法,有需要的小伙伴可以參考下。2016-03-03深入理解Mysql事務(wù)隔離級(jí)別與鎖機(jī)制問(wèn)題
MySQL默認(rèn)的事務(wù)隔離級(jí)別是可重復(fù)讀,用Spring開(kāi)發(fā)程序時(shí),如果不設(shè)置隔離級(jí)別默認(rèn)用MySQL設(shè)置的隔離級(jí)別,如果Spring設(shè)置了就用已設(shè)置的隔離級(jí)別,本文重點(diǎn)給大家介紹Mysql事務(wù)隔離級(jí)別與鎖機(jī)制的相關(guān)知識(shí),一起看看吧2021-09-09MySQL 5.7并發(fā)復(fù)制隱式bug實(shí)例分析
這篇文章主要給大家介紹了關(guān)于MySQL 5.7并發(fā)復(fù)制隱式bug的相關(guān)資料,文中介紹的非常詳細(xì),對(duì)大家學(xué)習(xí)或者使用mysql5.7具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2018-11-11MySql官方手冊(cè)學(xué)習(xí)筆記1 MySql簡(jiǎn)單上手
這是我學(xué)習(xí)MySql 5.1時(shí)做的一些整理與筆記,希望能理一理自己學(xué)到的東西,如果能有助于各位同道學(xué)習(xí)MySql那就更是意外之喜了,呵呵2012-10-10