千鋒教育-做有情懷、有良心、有品質(zhì)的職業(yè)教育機(jī)構(gòu)

手機(jī)站
千鋒教育

千鋒學(xué)習(xí)站 | 隨時(shí)隨地免費(fèi)學(xué)

千鋒教育

掃一掃進(jìn)入千鋒手機(jī)站

領(lǐng)取全套視頻
千鋒教育

關(guān)注千鋒學(xué)習(xí)站小程序
隨時(shí)隨地免費(fèi)學(xué)習(xí)課程

當(dāng)前位置:首頁(yè)  >  技術(shù)干貨  > redis似乎并沒有“事務(wù)”,那些用到“事務(wù)”的人在做什么?

redis似乎并沒有“事務(wù)”,那些用到“事務(wù)”的人在做什么?

來源:千鋒教育
發(fā)布人:xqq
時(shí)間: 2023-10-11 23:10:14 1697037014

一、redis似乎并沒有“事務(wù)”,那些用到“事務(wù)”的人在做什么

Redis主要是針對(duì)單個(gè)key,或者說,單個(gè)數(shù)據(jù)對(duì)象的操作,這樣,事務(wù)里的多對(duì)象Atomic要求就很低。

當(dāng)Redis的命令執(zhí)行多對(duì)象操作,比如MSET命令,或者Redis的Transaction命令(也含LUA),涉及多數(shù)據(jù)對(duì)象時(shí),其內(nèi)部,是順序執(zhí)行的(這也是我們說的,Redis是單線程架構(gòu)),相當(dāng)于傳統(tǒng)DB的Serialize級(jí)別。這時(shí),ACID里的Isolation在Redis里就極其簡(jiǎn)化,因?yàn)椴淮嬖趦蓚€(gè)并發(fā)事務(wù)互相的干擾,即Redis不存在并發(fā)命令。

Redis的Transaction命令,不是嚴(yán)格意義的事務(wù),因?yàn)槿狈ollback。

磁盤的AOF或RDB文件,只是個(gè)備份,不是傳統(tǒng)意義上的DB的Dataset包含磁盤數(shù)據(jù)的概念,所以,把Redis的磁盤數(shù)據(jù),看成整個(gè)Dataset的一部分,是不對(duì)的,還是只考慮Redis的內(nèi)存特性,即它是內(nèi)存數(shù)據(jù)庫(kù)。

Redis 只是提供了簡(jiǎn)單的事務(wù)功能。其本質(zhì)是一組命令的集合,事務(wù)支持一次執(zhí)行多個(gè)命令,在事務(wù)執(zhí)行過程中,會(huì)順序執(zhí)行隊(duì)列中的命令,其他客戶端提交的命令請(qǐng)求不會(huì)插入到本事務(wù)執(zhí)行命令序列中。命令的執(zhí)行過程是順序執(zhí)行的,但不能保證原子性。無法像 MySQL 那樣,有隔離級(jí)別,出了問題之后還能回滾數(shù)據(jù)等高級(jí)操作。

延伸閱讀:

二、Redis事務(wù)的應(yīng)用場(chǎng)景

在分布式系統(tǒng)和高并發(fā)場(chǎng)景下,事務(wù)處理具有重要意義。Redis事務(wù)可以確保數(shù)據(jù)的一致性,避免并發(fā)操作導(dǎo)致的數(shù)據(jù)不一致問題。以下是一些Redis事務(wù)的應(yīng)用場(chǎng)景:

批量操作:Redis 事務(wù)可以將多個(gè)命令打包成一個(gè)單元來執(zhí)行,可以減少與 Redis 服務(wù)器的通信次數(shù),從而提高性能。數(shù)據(jù)庫(kù)遷移:在遷移數(shù)據(jù)時(shí),需要保證數(shù)據(jù)一致性。通過Redis事務(wù),可以確保數(shù)據(jù)在遷移過程中不會(huì)出現(xiàn)不一致的情況。分布式鎖:在分布式系統(tǒng)中,為了保證數(shù)據(jù)的一致性,需要實(shí)現(xiàn)分布式鎖。通過Redis事務(wù),可以在同一個(gè)事務(wù)中執(zhí)行鎖定、解鎖等操作,確保鎖的原子性。

這些應(yīng)用場(chǎng)景展示了Redis事務(wù)在實(shí)際應(yīng)用中的價(jià)值。接下來,我們將詳細(xì)介紹Redis事務(wù)的基本命令、特性和實(shí)現(xiàn)原理。

聲明:本站稿件版權(quán)均屬千鋒教育所有,未經(jīng)許可不得擅自轉(zhuǎn)載。
10年以上業(yè)內(nèi)強(qiáng)師集結(jié),手把手帶你蛻變精英
請(qǐng)您保持通訊暢通,專屬學(xué)習(xí)老師24小時(shí)內(nèi)將與您1V1溝通
免費(fèi)領(lǐng)取
今日已有369人領(lǐng)取成功
劉同學(xué) 138****2860 剛剛成功領(lǐng)取
王同學(xué) 131****2015 剛剛成功領(lǐng)取
張同學(xué) 133****4652 剛剛成功領(lǐng)取
李同學(xué) 135****8607 剛剛成功領(lǐng)取
楊同學(xué) 132****5667 剛剛成功領(lǐng)取
岳同學(xué) 134****6652 剛剛成功領(lǐng)取
梁同學(xué) 157****2950 剛剛成功領(lǐng)取
劉同學(xué) 189****1015 剛剛成功領(lǐng)取
張同學(xué) 155****4678 剛剛成功領(lǐng)取
鄒同學(xué) 139****2907 剛剛成功領(lǐng)取
董同學(xué) 138****2867 剛剛成功領(lǐng)取
周同學(xué) 136****3602 剛剛成功領(lǐng)取
相關(guān)推薦HOT
mysql inner join為什么不走索引?

一、mysql inner join為什么不走索引因?yàn)樗饕膬?yōu)勢(shì)是在大表中過濾出小的結(jié)果集進(jìn)行聯(lián)接,mysql inner join句根本沒有任何過濾條件。另外表很小...詳情>>

2023-10-11 23:07:14
Geode和redis兩個(gè)分布式內(nèi)存數(shù)據(jù)庫(kù)的對(duì)比,優(yōu)缺點(diǎn)?

一、Geode和redis兩個(gè)分布式內(nèi)存數(shù)據(jù)庫(kù)的對(duì)比兩者的定位不一樣。Geode是分布式內(nèi)存數(shù)據(jù)庫(kù),提供了可配置的一致性保證,能夠保證數(shù)據(jù)不丟失,更...詳情>>

2023-10-11 22:50:49
InnoDB的next-key lock為什么是左開右閉的?

一、InnoDB的next-key lock為什么是左開右閉的InnoDB的next-key lock本身的設(shè)計(jì)方案就是左開右閉的,例如select * from t where c2 = 10 fo詳情>>

2023-10-11 22:48:02
到底哪些APP在用Flutter?

一、滴滴出行滴滴出行是一款出行服務(wù)平臺(tái),提供打車、順風(fēng)車、單車等多種出行方式。在采用Flutter技術(shù)后,滴滴出行成功實(shí)現(xiàn)了Android和iOS平臺(tái)...詳情>>

2023-10-11 22:45:35
web前端和UI前端的區(qū)別?

一、職責(zé)不同Web前端主要負(fù)責(zé)開發(fā)網(wǎng)站的前端部分,通過編寫代碼實(shí)現(xiàn)網(wǎng)站的用戶界面和交互功能。而UI前端(也稱為UI設(shè)計(jì)師或UI工程師)負(fù)責(zé)設(shè)計(jì)...詳情>>

2023-10-11 22:40:09
快速通道