03-事務(wù)

定義

保證一組操作要么全部成功恭理,要么全部失敗。
引擎層實(shí)現(xiàn)

ACID特性

ACID(Atomicity郭变、Consistency颜价、Isolation、Durability诉濒,即原子性周伦、一致性、隔離性未荒、持久性)

  • 原子性:最小操作單位
  • 一致性:事務(wù)操作前后专挪,數(shù)據(jù)總量不變
  • 隔離性:多個(gè)事務(wù)間,相互獨(dú)立
  • 持久性:提交片排、回滾后寨腔,持久化保存

隔離性 & 隔離級(jí)別

  • 讀未提交(read uncommitted):
    讀到了其他事務(wù)未提交的數(shù)據(jù),即臟讀(dirty read)
  • 讀已提交(read committed):
    其他事務(wù)提交前率寡、提交后迫卢,當(dāng)前事務(wù)兩次查詢(xún)到的數(shù)據(jù)不一致,即不可重復(fù)讀(non-repeatable read)
  • 可重復(fù)讀(repeatable read):
    保證一個(gè)事務(wù)執(zhí)行過(guò)程中看到數(shù)據(jù)前后一致冶共。但假如其他事務(wù)有insert乾蛤、delete、update操作捅僵,改變了數(shù)據(jù)量家卖,當(dāng)前事務(wù)將無(wú)法通過(guò)select獲得這些改變結(jié)果,即幻讀(phantom read)庙楚。
    另外的解釋?zhuān)耗骋淮蔚?select 操作得到的結(jié)果所表征的數(shù)據(jù)狀態(tài)無(wú)法支撐后續(xù)的業(yè)務(wù)操作上荡。
  • 串行化(serializable)
    將記錄加鎖,鎖沖突時(shí)必須等待當(dāng)前操作事務(wù)的提交或回滾后馒闷,才能操作酪捡。
    解決一切問(wèn)題

修改隔離界別:

-- 可選參數(shù)有:
-- READ-UNCOMMITTED, 
-- READ-COMMITTED, 
-- REPEATABLE-READ,
-- SERIALIZABLE
transaction-isolation = xxx

事務(wù)隔離的實(shí)現(xiàn)

各個(gè)read-view通過(guò)回滾日志,讀取到一個(gè)數(shù)值的不同版本窜司,這是通過(guò)MVCC多版本并發(fā)控制實(shí)現(xiàn)的沛善。
一個(gè)回滾日志,將在系統(tǒng)里沒(méi)有比此日志更早的read-view的時(shí)候被刪除塞祈。


建議:盡量避免使用長(zhǎng)事務(wù)金刁。

  • 占用大量存儲(chǔ)空間:
    長(zhǎng)事務(wù)中存在許多老舊的任務(wù)視圖,這個(gè)長(zhǎng)事務(wù)提交前,它可能用到的回滾記錄都必須保留尤蛮,導(dǎo)致占用大量存儲(chǔ)空間媳友。
  • 占用鎖資源
-- 查詢(xún)持續(xù)時(shí)間超過(guò)60s的長(zhǎng)事務(wù)
select * from information_schema.innodb_trx 
where TIME_TO_SEC(timediff(now(),trx_started))>60
回滾日志

事務(wù)啟動(dòng)方式

-- 1、顯示啟動(dòng)事務(wù)-----------------------------
begin transaction
## 或
start transaction
# 具體操作
commit
## 或
rollback
-- 2产捞、關(guān)閉當(dāng)前線程自動(dòng)提交--------------------
set autocommit=0
# 具體操作
# 任何query語(yǔ)句都將啟動(dòng)事務(wù)醇锚,且必須手動(dòng)提交或回滾
# 可能導(dǎo)致意外的長(zhǎng)事務(wù)
commit
## 或
rollback

建議:使用顯示啟動(dòng)事務(wù)的方式

如何避免長(zhǎng)事務(wù)對(duì)業(yè)務(wù)的影響

應(yīng)用開(kāi)發(fā)端:

  • 打開(kāi)自動(dòng)提交:set autocommit=1
  • 確認(rèn)是否有不必要的只讀業(yè)務(wù),可以去掉坯临。
  • set max_execution_time焊唬,控制每個(gè)語(yǔ)句的最長(zhǎng)執(zhí)行時(shí)間。

數(shù)據(jù)庫(kù)端:

  • 監(jiān)控information_schema.innodb_trx表看靠,設(shè)置長(zhǎng)事務(wù)閾值赶促,超過(guò)就報(bào)警、KILL
  • 業(yè)務(wù)功能測(cè)試階段挟炬,輸出所有g(shù)eneral_log鸥滨,分析日志行為,提前發(fā)現(xiàn)
  • 5.6 or higher谤祖,把innodb_undo_tablespaces設(shè)置成2
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末婿滓,一起剝皮案震驚了整個(gè)濱河市,隨后出現(xiàn)的幾起案子粥喜,更是在濱河造成了極大的恐慌凸主,老刑警劉巖,帶你破解...
    沈念sama閱讀 216,843評(píng)論 6 502
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件容客,死亡現(xiàn)場(chǎng)離奇詭異秕铛,居然都是意外死亡,警方通過(guò)查閱死者的電腦和手機(jī)缩挑,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,538評(píng)論 3 392
  • 文/潘曉璐 我一進(jìn)店門(mén),熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái)鬓梅,“玉大人供置,你說(shuō)我怎么就攤上這事≌揽欤” “怎么了芥丧?”我有些...
    開(kāi)封第一講書(shū)人閱讀 163,187評(píng)論 0 353
  • 文/不壞的土叔 我叫張陵,是天一觀的道長(zhǎng)坊罢。 經(jīng)常有香客問(wèn)我续担,道長(zhǎng),這世上最難降的妖魔是什么活孩? 我笑而不...
    開(kāi)封第一講書(shū)人閱讀 58,264評(píng)論 1 292
  • 正文 為了忘掉前任物遇,我火速辦了婚禮,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘询兴。我一直安慰自己乃沙,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,289評(píng)論 6 390
  • 文/花漫 我一把揭開(kāi)白布诗舰。 她就那樣靜靜地躺著警儒,像睡著了一般。 火紅的嫁衣襯著肌膚如雪眶根。 梳的紋絲不亂的頭發(fā)上蜀铲,一...
    開(kāi)封第一講書(shū)人閱讀 51,231評(píng)論 1 299
  • 那天,我揣著相機(jī)與錄音属百,去河邊找鬼蝙茶。 笑死,一個(gè)胖子當(dāng)著我的面吹牛诸老,可吹牛的內(nèi)容都是我干的隆夯。 我是一名探鬼主播,決...
    沈念sama閱讀 40,116評(píng)論 3 418
  • 文/蒼蘭香墨 我猛地睜開(kāi)眼别伏,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼蹄衷!你這毒婦竟也來(lái)了?” 一聲冷哼從身側(cè)響起厘肮,我...
    開(kāi)封第一講書(shū)人閱讀 38,945評(píng)論 0 275
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤愧口,失蹤者是張志新(化名)和其女友劉穎,沒(méi)想到半個(gè)月后类茂,有當(dāng)?shù)厝嗽跇?shù)林里發(fā)現(xiàn)了一具尸體耍属,經(jīng)...
    沈念sama閱讀 45,367評(píng)論 1 313
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,581評(píng)論 2 333
  • 正文 我和宋清朗相戀三年巩检,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了厚骗。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 39,754評(píng)論 1 348
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡兢哭,死狀恐怖领舰,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情迟螺,我是刑警寧澤冲秽,帶...
    沈念sama閱讀 35,458評(píng)論 5 344
  • 正文 年R本政府宣布,位于F島的核電站矩父,受9級(jí)特大地震影響锉桑,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜窍株,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,068評(píng)論 3 327
  • 文/蒙蒙 一民轴、第九天 我趴在偏房一處隱蔽的房頂上張望攻柠。 院中可真熱鬧,春花似錦杉武、人聲如沸辙诞。這莊子的主人今日做“春日...
    開(kāi)封第一講書(shū)人閱讀 31,692評(píng)論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)飞涂。三九已至,卻和暖如春祈搜,著一層夾襖步出監(jiān)牢的瞬間较店,已是汗流浹背。 一陣腳步聲響...
    開(kāi)封第一講書(shū)人閱讀 32,842評(píng)論 1 269
  • 我被黑心中介騙來(lái)泰國(guó)打工容燕, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留梁呈,地道東北人。 一個(gè)月前我還...
    沈念sama閱讀 47,797評(píng)論 2 369
  • 正文 我出身青樓蘸秘,卻偏偏與公主長(zhǎng)得像官卡,于是被迫代替她去往敵國(guó)和親。 傳聞我的和親對(duì)象是個(gè)殘疾皇子醋虏,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 44,654評(píng)論 2 354

推薦閱讀更多精彩內(nèi)容