Redis事務(wù)的概念
Redis事務(wù)的本質(zhì)是一系列命令的集合。事務(wù)支持一次執(zhí)行多個(gè)命令阳仔,一個(gè)事務(wù)中所有的命令都會(huì)被序列化掸冤。在事務(wù)的執(zhí)行過(guò)程中,會(huì)按照順序串行化執(zhí)行隊(duì)列中的命令食呻,其他客戶端提交的命令請(qǐng)求不會(huì)插入到事務(wù)執(zhí)行命令序列中流炕。
總結(jié)來(lái)說(shuō):Redis事務(wù)就是一次性澎现、順序性、排他性的執(zhí)行一個(gè)隊(duì)列中的一系列命令每辟。
與Mysql事務(wù)的區(qū)別
1)Redis事務(wù)沒(méi)有隔離級(jí)別的概念:
批量指令在發(fā)送EXEC命令之前被依次放入隊(duì)列中剑辫,并不會(huì)被實(shí)際執(zhí)行,也就不存在事務(wù)內(nèi)的查詢要看到事務(wù)里的更新影兽,事務(wù)外查詢不能看到揭斧。
2)Redis事務(wù)不保證原子性:
Redis中,單條命令是原子性執(zhí)行的峻堰,但是事務(wù)不保證原子性讹开,且沒(méi)有回滾。事務(wù)中任意命令執(zhí)行失敗捐名,其余的命令仍會(huì)被執(zhí)行旦万。
Redis事務(wù)的三個(gè)階段
1)開(kāi)始事務(wù)
2)命令入隊(duì)
3)執(zhí)行事務(wù)
Redis事務(wù)命令
- 1、DISCARD 取消事務(wù)镶蹋,放棄執(zhí)行事務(wù)塊內(nèi)的所有命令
- 2成艘、MULTI 標(biāo)記一個(gè)事務(wù)塊的開(kāi)始
- 3、EXEC 執(zhí)行所有事務(wù)塊內(nèi)的命令
- 4贺归、WATCH key [key ...] 監(jiān)視一個(gè)或多個(gè)key淆两,如果在事務(wù)執(zhí)行之前這個(gè)/些key被其他命令所改動(dòng),那么事務(wù)將被打斷
- 5拂酣、UNWATCH 取消WATCH命令對(duì)所有key的監(jiān)視
Redis事務(wù)驗(yàn)證
1)不保證原子性
127.0.0.1:6379> MULTI
OK
127.0.0.1:6379> set key1 1
QUEUED
127.0.0.1:6379> set key2 2
QUEUED
127.0.0.1:6379> SADD key2 3
QUEUED
127.0.0.1:6379> EXEC
1) OK
2) OK
3) (error) WRONGTYPE Operation against a key holding the wrong kind of value
127.0.0.1:6379> get key1
"1"
2) 監(jiān)視key
如圖所示秋冰,在當(dāng)前事務(wù)執(zhí)行開(kāi)始之前對(duì)key1進(jìn)行監(jiān)視,如果在此事務(wù)執(zhí)行EXEC之前在另一個(gè)客戶端對(duì)key1進(jìn)行修改婶熬,則當(dāng)前事務(wù)會(huì)執(zhí)行失敗剑勾,執(zhí)行結(jié)果為nil。
總結(jié)
1)Redis事務(wù)提供了一種將多個(gè)命令打包赵颅,然后一次性虽另、有序性執(zhí)行的機(jī)制。
2)在事務(wù)中饺谬,多個(gè)命令會(huì)被入隊(duì)到事務(wù)隊(duì)列中捂刺,然后按FIFO的順序執(zhí)行。
3)事務(wù)在執(zhí)行過(guò)程中不會(huì)被中斷商蕴,當(dāng)事務(wù)隊(duì)列中的所有命令執(zhí)行完畢后叠萍,事務(wù)才會(huì)結(jié)束。
4)帶有WATCH命令的事務(wù)會(huì)將客戶端和被監(jiān)視的鍵在數(shù)據(jù)庫(kù)中的watch_keys字典關(guān)聯(lián)绪商,當(dāng)鍵被修改時(shí)苛谷,程序會(huì)將所有監(jiān)視被修改鍵的客戶端的REDIS_DIRTY_CAS標(biāo)識(shí)打開(kāi),服務(wù)只有在REDIS_DIRTY_CAS標(biāo)識(shí)沒(méi)有打開(kāi)時(shí)格郁,才會(huì)執(zhí)行客戶端提交的事務(wù)腹殿,否做拒絕執(zhí)行事務(wù)独悴。
5)Redis中的事務(wù)不支持回滾機(jī)制。