Redis事務控制

来源:https://www.cnblogs.com/godoforange/archive/2019/09/18/11546203.html
-Advertisement-
Play Games

Redis事務控制 1、Redis事務控制的相關命令彙總 |命令名|作用| | | | |MULTI|表示開始收集命令,後面所有命令都不是馬上執行,而是加入到一個隊列中。| |EXEC|執行MULTI後面命令隊列中的所有命令。| |DISCARD|放棄執行隊列中的命令。| |WATCH|“觀察”、“ ...


Redis事務控制

1、Redis事務控制的相關命令彙總

命令名 作用
MULTI 表示開始收集命令,後面所有命令都不是馬上執行,而是加入到一個隊列中。
EXEC 執行MULTI後面命令隊列中的所有命令。
DISCARD 放棄執行隊列中的命令。
WATCH “觀察”、“監控”一個KEY,在當前隊列外的其他命令操作這個KEY時,放棄執行自己隊列的命令
UNWATCH 放棄監控一個KEY

我們先測試一下

MULTI
SET number 100
INCR number
EXEC

執行效果如下所示:

當我們執行中間出錯時,整個事務都會失敗而且回滾。

這裡如果我們之前學過資料庫的話,應該覺得很正常

但是當我們執行以下命令時

MULTI
SET number 1000
incr number
incr number
incriby number aaa
exec

運行結果如下

我們會發現整個事務並沒有回滾

對於此官方解釋了:

如果你有使用關係式資料庫的經驗, 那麼 “Redis 在事務失敗時不進行回滾,而是繼續執行餘下的命令”這種做法可能會讓你覺得有點奇怪。以下是這種做法的優點:
Redis 命令只會因為錯誤的語法而失敗(並且這些問題不能在入隊時發現),或是命令用在了錯誤類型的鍵上面:這也就是說,從實用性的角度來說,失敗的命令是由編程錯誤造成的,而這些錯誤應該在開發的過程中被髮現,而不應該出現在生產環境中。
因為不需要對回滾進行支持,所以 Redis 的內部可以保持簡單且快速。
有種觀點認為 Redis 處理事務的做法會產生 bug , 然而需要註意的是, 在通常情況下, 回滾並不能解決編程錯誤帶來的問題。 舉個例子, 如果你本來想通過 INCR 命令將鍵的值加上 1 , 卻不小心加上了 2 , 又或者對錯誤類型的鍵執行了 INCR , 回滾是沒有辦法處理這些情況的。

因我我們需要加強對生產環境中的錯誤異常處理

2、Redis樂觀鎖的體現

我們先來執行以下代碼

set num 100
get num
watch num
MULTI
incr num
incr num
get num

然後我們新開一個客戶端,設置了一下num的值

然後在剛纔的界面執行EXEC

這時候我們會發現命令執行失敗了,整個事務回滾了。

這就是一個樂觀鎖的體現,
簡而言之就是、如果別人在我的隊列命令執行之前,修改了我的數據,那我就直接放棄了。

樂觀鎖和悲觀鎖需要依據具體的實現進行使用

  • 悲觀鎖(資料庫中的行鎖和表鎖)
    • 認為當前環境非常容易發生碰撞,所以執行操作前需要把數據鎖定,操作完成後釋放鎖其他操作才能繼續進行操作。
  • 樂觀鎖
    • 認為當前環境不容易發生碰撞,所以執行操作前不鎖定數據,萬一碰撞真的發生了,那麼放棄自己的操作

Redis 內只有樂觀鎖,並無悲觀鎖,因為Redis對性能的要求很高。


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • CentOS 預設只有一個 root 用戶,但是 root 用戶的許可權過大,而且不利於多人協作,基於許可權管理和安全的原因,我們為系統新建一個用戶,並且使能其 SSH 登錄,同時禁止 root 用戶的登錄; ...
  • 一、ramdisk介紹 ramdisk通過直面意思就大概能理解意思,ram disk虛擬記憶體盤,將ram模擬成硬碟來使用的文件系統。對於傳統的磁碟文件系統來說,這樣做的好處是可以極大提高文件訪問速度;但由於是ram,所以 在掉電後,這部分內容不能保存。ramdisk文件系統是在系統上電後直接從磁碟一 ...
  • 比較 新的Linux發行版 已經沒有 文件了。因為已經將其服務化了。 解決方法: 1、設置 2、激活 3、添加啟動服務 手工創建或者拷貝已有的/etc/rc.local,並賦予執行許可權 ...
  • 摘要 Recovery模式指的是一種可以對安卓機內部的數據或系統進行修改的模式(類似於windows PE或DOS)。也可以稱之為安卓的恢復模式,在這個所謂的恢復模式下,我們可以刷入新的安卓系統,或者對已有的系統進行備份或升級,也可以在此恢復出廠設置(格式化數據和緩存)。 1. Recovery相關 ...
  • 執行:systemctl get-default //顯示預設的界面方式 multi-user.target //命令行界面 graphical.target //圖形化界面 執行:systemctl set-default multi-user.target //設置開機以命令行模式界面啟動 執行 ...
  • 最近在做一個VPN中間件的配置工作,在配置iptables的時候,當用戶想刪除EIP(即釋放當前連接),發現使用iptables的相關命令會提示錯誤。 我就納悶了,怎麼會出現這個問題,按照官方的文檔也有錯? "官方文檔地址" 解決方法: 1. 按行刪除 如果按照行號刪除,就不會有這篇文章了,當然如果 ...
  • 利用 pandas庫讀取excel表格數據 初入IT行業,願與大家一起學習,共同進步,有問題請指出!! 還在為數據讀取而頭疼呢,請看下方簡潔介紹: 數據來源為國家統計局網站下載: 具體方法 代碼: 結果: 讀出x列的結果可以用matplotlib.pyplot庫繪製直線圖、餅圖、折線圖 ...
  • 系統:win10(其他版本系統不在本次內容) MYSQL下載地址:https://dev.mysql.com/downloads/mysql/ MySQL安裝主流分為兩種:msi,zip Zip:壓縮版,這需要配置init文件,然後通過win+R 進入cmd控制台進行操作(本次 以msi版本為主,後 ...
一周排行
    -Advertisement-
    Play Games
  • .Net8.0 Blazor Hybird 桌面端 (WPF/Winform) 實測可以完整運行在 win7sp1/win10/win11. 如果用其他工具打包,還可以運行在mac/linux下, 傳送門BlazorHybrid 發佈為無依賴包方式 安裝 WebView2Runtime 1.57 M ...
  • 目錄前言PostgreSql安裝測試額外Nuget安裝Person.cs模擬運行Navicate連postgresql解決方案Garnet為什麼要選擇Garnet而不是RedisRedis不再開源Windows版的Redis是由微軟維護的Windows Redis版本老舊,後續可能不再更新Garne ...
  • C#TMS系統代碼-聯表報表學習 領導被裁了之後很快就有人上任了,幾乎是無縫銜接,很難讓我不想到這早就決定好了。我的職責沒有任何變化。感受下來這個系統封裝程度很高,我只要會調用方法就行。這個系統交付之後不會有太多問題,更多應該是做小需求,有大的開發任務應該也是第二期的事,嗯?怎麼感覺我變成運維了?而 ...
  • 我在隨筆《EAV模型(實體-屬性-值)的設計和低代碼的處理方案(1)》中介紹了一些基本的EAV模型設計知識和基於Winform場景下低代碼(或者說無代碼)的一些實現思路,在本篇隨筆中,我們來分析一下這種針對通用業務,且只需定義就能構建業務模塊存儲和界面的解決方案,其中的數據查詢處理的操作。 ...
  • 對某個遠程伺服器啟用和設置NTP服務(Windows系統) 打開註冊表 HKEY_LOCAL_MACHINE\SYSTEM\CurrentControlSet\Services\W32Time\TimeProviders\NtpServer 將 Enabled 的值設置為 1,這將啟用NTP伺服器功 ...
  • title: Django信號與擴展:深入理解與實踐 date: 2024/5/15 22:40:52 updated: 2024/5/15 22:40:52 categories: 後端開發 tags: Django 信號 松耦合 觀察者 擴展 安全 性能 第一部分:Django信號基礎 Djan ...
  • 使用xadmin2遇到的問題&解決 環境配置: 使用的模塊版本: 關聯的包 Django 3.2.15 mysqlclient 2.2.4 xadmin 2.0.1 django-crispy-forms >= 1.6.0 django-import-export >= 0.5.1 django-r ...
  • 今天我打算整點兒不一樣的內容,通過之前學習的TransformerMap和LazyMap鏈,想搞點不一樣的,所以我關註了另外一條鏈DefaultedMap鏈,主要調用鏈為: 調用鏈詳細描述: ObjectInputStream.readObject() DefaultedMap.readObject ...
  • 後端應用級開發者該如何擁抱 AI GC?就是在這樣的一個大的浪潮下,我們的傳統的應用級開發者。我們該如何選擇職業或者是如何去快速轉型,跟上這樣的一個行業的一個浪潮? 0 AI金字塔模型 越往上它的整個難度就是職業機會也好,或者說是整個的這個運作也好,它的難度會越大,然後越往下機會就會越多,所以這是一 ...
  • @Autowired是Spring框架提供的註解,@Resource是Java EE 5規範提供的註解。 @Autowired預設按照類型自動裝配,而@Resource預設按照名稱自動裝配。 @Autowired支持@Qualifier註解來指定裝配哪一個具有相同類型的bean,而@Resourc... ...