<em>Mac</em>Book项目 2009年学校开始实施<em>Mac</em>Book项目,所有师生配备一本<em>Mac</em>Book,并同步更新了校园无线网络。学校每周进行电脑技术更新,每月发送技术支持资料,极大改变了教学及学习方式。因此2011
2021-06-01 09:32:01
說到事務,大家會立刻想到Mysql的事務,所謂的事務就是對資料進行一系列的操作,要麼都執行成功,要麼都執行失敗,事務提供了原子性(Atomicity)、一致性(Consistency)、隔離性(Isolation)、永續性(Durability),簡稱ACID。這些屬性既包括了對事務執行結果的要求,也有對資料庫在事務執行前後的資料狀態變化的要求。那麼Redis的事務能支援ACID嗎?
事務中的全部操作在資料庫中是不可分割的,要麼全部完成,要麼全部不執行。
事務的執行使資料從一個狀態轉換為另一個狀態,在事務開始之前和事務結束之後,資料庫的完整性約束沒有被破壞。
事務的隔離性要求每個讀寫事務的物件對其他事務的操作物件相互分離,即該事務提交前對其他事務都不可見。
資料庫執行事務後,資料的修改要被持久化儲存下來。當資料庫重啟後,資料的值需要是被修改後的值。
Redis事務的執行包含了三個步驟,具體如下:
使用者端使用MULTI命令顯式地開啟一個事務。
使用者端把事務中本身要執行的具體操作(例如增刪改資料)傳送給伺服器端。這些操作就是Redis 本身提供的資料讀寫命令,雖然這些命令被使用者端傳送到了伺服器端,但是Redis範例只是把這些命令暫存到一個命令佇列中,並不會立即執行。
Redis執行EXEC命令執行事務提交,伺服器端收到EXEC命令後,才會實際執行命令佇列中的所有命令。
情況一範例說明
127.0.0.1:6379> multi OK 127.0.0.1:6379> set t1 v1 QUEUED 127.0.0.1:6379> set t2 v2 QUEUED 127.0.0.1:6379> setget t3 (error) ERR unknown command 'setget' 127.0.0.1:6379> set t4 v4 QUEUED 127.0.0.1:6379> exec (error) EXECABORT Transaction discarded because of previous errors. 127.0.0.1:6379> get t4 (nil)
說明:在執行exec命令之前,如果發生語法錯誤(使用了不存在的命令),那麼命令入隊時,Redis就會報錯並且記錄錯誤,等到執行Exec命令之後,Redi會拒絕所有提交的命令,事務執行失敗。這種情況Reids的事務是可以支援原子性。
情況二範例說明
127.0.0.1:6379> multi OK 127.0.0.1:6379> incr s2 QUEUED 127.0.0.1:6379> set a1 v1 QUEUED 127.0.0.1:6379> set a2 v2 QUEUED 127.0.0.1:6379> exec 1) (error) ERR value is not an integer or out of range 2) OK 3) OK 127.0.0.1:6379> get a2 "v2"
說明: s2的值為v2,當執行incr命令時報報錯,因為incr只能新增integer的型別值,但是這種情況下我們發現Redis的事務沒有進行回滾,後面的命令能夠執行成功,所以這種情況下時無法保證事務的原子性。
針對第一種情況,事務本身就會被放棄執行,所以可以保證事務的一致性。
針對第二種情況,有錯誤的命令不會被執行,正確的命令可以正常執行,也不會改變資料庫的一致性。
如果Redis持久化設定為RDB,那麼生成RDB快照不會在事務執行時執行,所以事務命令操作的結果不會被儲存到RDB快照中,使用RDB快照進行恢復時,資料庫裡的資料也是一致的。
如果Reids持久化設定為AOF,而事務操作還沒有被記錄到AOF紀錄檔時,範例就發生了故障,那麼,使用AOF紀錄檔恢復的資料庫資料是一致的。如果只有部分操作被記錄到了AOF紀錄檔,我們可以使用 redis-check-aof 清除事務中已經完成的操作,資料庫恢復後也是一致的。
Redis實現事務的隔離性,需要通過watch命令來支援事務隔離性。Watch的原理是,在事務執行前,監控一個或者多個鍵的變化時,當事務呼叫EXEC命令執行時,WATCH機制會先檢查監控的鍵是否被其它使用者端修改了。如果修改了監聽的值,就放棄事務執行,避免事務的隔離性被破壞。
範例說明
使用者端1:
127.0.0.1:6379> get blance "100" 127.0.0.1:6379> watch blance OK 127.0.0.1:6379> multi OK 127.0.0.1:6379> decrby blance 10 QUEUED 127.0.0.1:6379> incrby blance 10 QUEUED 127.0.0.1:6379> exec (nil)
使用者端2:
127.0.0.1:6379> get blance "100" 127.0.0.1:6379> set blance 90 OK 127.0.0.1:6379> get blance "90"
說明:使用者端1使用watch檢測balance,在開啟事務後,在使用者端2執行更改balance的值操作,模擬其他使用者端在事務執行期間更改watch監控的資料,然後再執行使用者端1的EXEC命令,發現事務未成功執行。
Redis的事務無法支援永續性,如果Redis使用了RDB模式,一個事務執行後,當下一次的RDB快照還未執行前,Redis發生了範例宕機,那麼這種情況下,事務修改的資料是無法保證持久化的,如果Redis採用AOF模式,如論持久化設定為no、everysec和always都可能會存在資料丟失,所以,不管 Redis採用那種持久化模式,事務的永續性都無法支援。
本文對Redis的事務進行詳細的講解,Redis對於事務的支援還是有限制的,所以大家在使用的過程中需要注意。
到此這篇關於你瞭解Redis事務嗎的文章就介紹到這了,更多相關Redis 事務內容請搜尋it145.com以前的文章或繼續瀏覽下面的相關文章希望大家以後多多支援it145.com!
相關文章
<em>Mac</em>Book项目 2009年学校开始实施<em>Mac</em>Book项目,所有师生配备一本<em>Mac</em>Book,并同步更新了校园无线网络。学校每周进行电脑技术更新,每月发送技术支持资料,极大改变了教学及学习方式。因此2011
2021-06-01 09:32:01
综合看Anker超能充系列的性价比很高,并且与不仅和iPhone12/苹果<em>Mac</em>Book很配,而且适合多设备充电需求的日常使用或差旅场景,不管是安卓还是Switch同样也能用得上它,希望这次分享能给准备购入充电器的小伙伴们有所
2021-06-01 09:31:42
除了L4WUDU与吴亦凡已经多次共事,成为了明面上的厂牌成员,吴亦凡还曾带领20XXCLUB全队参加2020年的一场音乐节,这也是20XXCLUB首次全员合照,王嗣尧Turbo、陈彦希Regi、<em>Mac</em> Ova Seas、林渝植等人全部出场。然而让
2021-06-01 09:31:34
目前应用IPFS的机构:1 谷歌<em>浏览器</em>支持IPFS分布式协议 2 万维网 (历史档案博物馆)数据库 3 火狐<em>浏览器</em>支持 IPFS分布式协议 4 EOS 等数字货币数据存储 5 美国国会图书馆,历史资料永久保存在 IPFS 6 加
2021-06-01 09:31:24
开拓者的车机是兼容苹果和<em>安卓</em>,虽然我不怎么用,但确实兼顾了我家人的很多需求:副驾的门板还配有解锁开关,有的时候老婆开车,下车的时候偶尔会忘记解锁,我在副驾驶可以自己开门:第二排设计很好,不仅配置了一个很大的
2021-06-01 09:30:48
不仅是<em>安卓</em>手机,苹果手机的降价力度也是前所未有了,iPhone12也“跳水价”了,发布价是6799元,如今已经跌至5308元,降价幅度超过1400元,最新定价确认了。iPhone12是苹果首款5G手机,同时也是全球首款5nm芯片的智能机,它
2021-06-01 09:30:45