Redis事务回滚深入
對于 Redis 而言,不單單需要注意其事務(wù)處理的過程,其回滾的能力也和數(shù)據(jù)庫不太一樣,這也是需要特別注意的一個問題——Redis 事務(wù)遇到的命令格式正確而數(shù)據(jù)類型不符合,如圖所示。
從圖中可知,我們將 key1 設(shè)置為字符串,而使用命令 incr 對其自增,但是命令只會進入事務(wù)隊列,而沒有被執(zhí)行,所以它不會有任何的錯誤發(fā)生,而是等待 exec 命令的執(zhí)行。
當(dāng) exec 命令執(zhí)行后,之前進入隊列的命令就依次執(zhí)行,當(dāng)遇到 incr 時發(fā)生命令操作的數(shù)據(jù)類型錯誤,所以顯示出了錯誤,而其之前和之后的命令都會被正常執(zhí)行。注意,這里命令格式是正確的,問題在于數(shù)據(jù)類型,對于命令格式是錯誤的卻是另外一種情形,如圖所示。
從圖中可以看到我們使用的 incr 命令格式是錯誤的,這個時候 Redis 會立即檢測出來并產(chǎn)生錯誤,而在此之前我們設(shè)置了 key1,在此之后我們設(shè)置了 key2。當(dāng)事務(wù)執(zhí)行的時候,我們發(fā)現(xiàn) key2 的值為空,說明被 Redis 事務(wù)回滾了。
通過上面兩個例子,可以看出在執(zhí)行事務(wù)命令的時候,在命令入隊的時候,Redis 就會檢測事務(wù)的命令是否正確,如果不正確則會產(chǎn)生錯誤。無論之前和之后的命令都會被事務(wù)所回滾,就變?yōu)槭裁炊紱]有執(zhí)行。
當(dāng)命令格式正確,而因為操作數(shù)據(jù)結(jié)構(gòu)引起的錯誤,則該命令執(zhí)行出現(xiàn)錯誤,而其之前和之后的命令都會被正常執(zhí)行。
對于一些重要的操作,我們必須通過程序去檢測數(shù)據(jù)的正確性,以保證 Redis 事務(wù)的正確執(zhí)行,避免出現(xiàn)數(shù)據(jù)不一致的情況。Redis 之所以保持這樣簡易的事務(wù),完全是為了保證移動互聯(lián)網(wǎng)的核心問題——性能。
總結(jié)
以上是生活随笔為你收集整理的Redis事务回滚深入的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: Java 解析本机
- 下一篇: MySQL 限制查询结果的记录数