搜尋
首頁資料庫Redisredis防坑指南-事務

redis防坑指南-事務

Jan 27, 2021 am 09:14 AM
redis事務

redis防坑指南-事務

相關指令介紹:

(學習影片分享:redis影片教學

redis防坑指南-事務

注意:

------MULTI,EXEC,DISCARD才是明確開啟並控制交易的常用指令,可類比關聯式資料庫中的 BEGAIN,COMMIT,ROLLBACK(事實上,差距很大);

------WATCH指令的使用是為了解決交易並發產生的不可重複讀和幻讀的問題(簡單理解為給Key加鎖);

#Redis交易

MULTI, EXEC, DISCARD and WATCH 是Redis事務的基礎。用來明確開啟並控制一個事務,它們允許在一個步驟中執行一組命令。並提供兩個重要的保證:

事務中的所有命令都會被序列化並按順序執行。在執行Redis事務的過程中,不會出現由另一個客戶端發出的請求。這保證命令佇列 作為一個單獨的原子操作被執行。

佇列中的指令要麼全部被處理,要麼全部被忽略。 EXEC命令觸發事務中所有命令的執行,因此,當客戶端在事務上下文中失去與伺服器的連接,如果發生在調用MULTI命令之前,則不執行任何commands;如果在此之前EXEC命令被調用,則所有的commands都被執行。

同時,redis使用AOF(append-only file),使用額外的write操作將交易寫入磁碟。如果發生宕機,進程奔潰等情況,可以使用redis-check-aof tool 修復append-only file,使服務正常啟動,並恢復部分操作。

用法

使用MULTI指令明確開啟Redis交易。該命令總是以OK回應。此時使用者可以發出多個命令,Redis不會執行這些命令,而是將它們排隊。 EXEC被呼叫後,所有的指令都會被執行。而呼叫DISCARD可以清除事務中的commands佇列並退出事務。

以下範例以原子方式,遞增鍵foo和bar。

>MULTI
OK
>INCR foo
QUEUED
>INCR bar
QUEUED
>EXEC
1)(整数)1
2)(整数)1

從上面的命令執行中可以看出,EXEC傳回一個數組,其中每個元素都是事務中單一命令的回傳結果,而且順序與命令的發出順序相同。 當Redis連線處於MULTI請求的上下文中時,所有命令將以字串QUEUED(從Redis協定的角度作為狀態回復發送)作為回复,並在命令佇列中排隊。只有EXEC被呼叫時,排隊的命令才會被執行,此時才會有真正的回傳結果。

交易中的錯誤

交易期間,可能會遇到兩種指令錯誤:

在呼叫EXEC指令之前出現錯誤(COMMAND排隊失敗)。例如,命令可能存在語法錯誤(參數數量錯誤,錯誤的命令名稱...);或者可能存在某些關鍵條件,例如記憶體不足的情況(如果伺服器使用maxmemory指令做了記憶體限制)。

客戶端會在EXEC呼叫之前偵測第一種錯誤。透過檢查排隊命令的狀態回复(***注意:這裡是指排隊的狀態回复,而不是執行結果***),如果命令使用QUEUED進行響應,則它已正確排隊,否則Redis將返回錯誤。如果排隊命令時發生錯誤,大多數用戶端將中止該交易並清除命令佇列。然而:

在Redis 2.6.5之前,這種情況下,在EXEC指令呼叫後,客戶端會執行指令的子集(成功排隊的指令)而忽略先前的錯誤。從Redis 2.6.5開始,服務端會記住在累積命令期間發生的錯誤,當EXEC命令呼叫時,將拒絕執行事務,並傳回這些錯誤,同時自動清除命令佇列。範例如下:

>MULTI
+OK
>INCR a b c
-ERR wrong number of arguments for 'incr' command

這是由於INCR指令的語法錯誤,將在呼叫EXEC之前被偵測出來,並終止交易(version2.6.5 )。

在呼叫EXEC指令之後出現錯誤。例如,使用錯誤的值對某個key執行操作(如針對String值呼叫List操作)

EXEC指令執行之後發生的錯誤並不會被特殊對待:即使事務中的某些指令執行失敗,其他命令仍會被正常執行。

範例如下:

>MULTI
+OK
>SET a 3
+QUEUED
>LPOP a
+QUEUED
>EXEC
*2
+OK
-ERR Operation against a key holding the wrong kind of value

EXEC傳回一個包含兩個元素的字串陣列,一個元素是OK,另一個是-ERR…。能否將錯誤合理的回饋給使用者這取決於客戶端library(如:Spring-data-redis.redisTemplate)的自身實作。要注意的是,即使指令失敗,佇列中的所有其他指令也會被處理----Redis不會停止指令的處理。

Redis事務不支援Rollback(重點)

事實上Redis指令在交易執行時可能會失敗,但仍會繼續執行剩餘指令而不是Rollback(交易回滾)。如果你使用過關聯式資料庫,這種情況可能會讓你感到很奇怪。然而針對這種情況具備很好的解釋:

Redis命令可能会执行失败,仅仅是由于错误的语法被调用(命令排队时检测不出来的错误),或者使用错误的数据类型操作某个Key: 这意味着,实际上失败的命令都是编程错误造成的,都是开发中能够被检测出来的,生产环境中不应该存在。(这番话,彻底甩锅,“都是你们自己编程错误,与我们无关”。)由于不必支持Rollback,Redis内部简洁并且更加高效。

“如果错误就是发生了呢?”这是一个反对Redis观点的争论。然而应该指出的是,通常情况下,回滚并不能挽救编程错误。鉴于没有人能够挽救程序员的错误,并且Redis命令失败所需的错误类型不太可能进入生产环境,所以我们选择了不支持错误回滚(Rollback)这种更简单快捷的方法。

清除命令队列

DISCARD被用来中止事务。事务中的所有命令将不会被执行,连接将恢复正常状态。

> SET foo 1
OK
> MULTI
OK
> INCR foo
QUEUED
> DISCARD
OK
> GET foo
"1"

相关推荐:redis数据库教程

以上是redis防坑指南-事務的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述
本文轉載於:掘金。如有侵權,請聯絡admin@php.cn刪除
REDIS:了解其架構和目的REDIS:了解其架構和目的Apr 26, 2025 am 12:11 AM

Redis是一种内存数据结构存储系统,主要用作数据库、缓存和消息代理。它的核心特点包括单线程模型、I/O多路复用、持久化机制、复制与集群功能。Redis在实际应用中常用于缓存、会话存储和消息队列,通过选择合适的数据结构、使用管道和事务、以及进行监控和调优,可以显著提升其性能。

REDIS與SQL數據庫:關鍵差異REDIS與SQL數據庫:關鍵差異Apr 25, 2025 am 12:02 AM

Redis和SQL數據庫的主要區別在於:Redis是內存數據庫,適用於高性能和靈活性需求;SQL數據庫是關係型數據庫,適用於復雜查詢和數據一致性需求。具體來說,1)Redis提供高速數據訪問和緩存服務,支持多種數據類型,適用於緩存和實時數據處理;2)SQL數據庫通過表格結構管理數據,支持複雜查詢和事務處理,適用於電商和金融系統等需要數據一致性的場景。

REDIS:它如何充當數據存儲和服務REDIS:它如何充當數據存儲和服務Apr 24, 2025 am 12:08 AM

REDISACTSASBOTHADATASTOREANDASERVICE.1)ASADATASTORE,ITUSESIN-MEMORYSTOOGATOFORFOFFASTESITION,支持VariousDatharptructuresLikeKey-valuepairsandsortedsetsetsetsetsetsetsets.2)asaservice,ItprovidespunctionslikeItionitionslikepunikeLikePublikePublikePlikePlikePlikeAndluikeAndluAascriptingiationsmpleplepleclexplectiations

REDIS與其他數據庫:比較分析REDIS與其他數據庫:比較分析Apr 23, 2025 am 12:16 AM

Redis與其他數據庫相比,具有以下獨特優勢:1)速度極快,讀寫操作通常在微秒級別;2)支持豐富的數據結構和操作;3)靈活的使用場景,如緩存、計數器和發布訂閱。選擇Redis還是其他數據庫需根據具體需求和場景,Redis在高性能、低延遲應用中表現出色。

REDIS的角色:探索數據存儲和管理功能REDIS的角色:探索數據存儲和管理功能Apr 22, 2025 am 12:10 AM

Redis在數據存儲和管理中扮演著關鍵角色,通過其多種數據結構和持久化機製成為現代應用的核心。 1)Redis支持字符串、列表、集合、有序集合和哈希表等數據結構,適用於緩存和復雜業務邏輯。 2)通過RDB和AOF兩種持久化方式,Redis確保數據的可靠存儲和快速恢復。

REDIS:了解NOSQL概念REDIS:了解NOSQL概念Apr 21, 2025 am 12:04 AM

Redis是一種NoSQL數據庫,適用於大規模數據的高效存儲和訪問。 1.Redis是開源的內存數據結構存儲系統,支持多種數據結構。 2.它提供極快的讀寫速度,適合緩存、會話管理等。 3.Redis支持持久化,通過RDB和AOF方式確保數據安全。 4.使用示例包括基本的鍵值對操作和高級的集合去重功能。 5.常見錯誤包括連接問題、數據類型不匹配和內存溢出,需注意調試。 6.性能優化建議包括選擇合適的數據結構和設置內存淘汰策略。

REDIS:現實世界的用例和示例REDIS:現實世界的用例和示例Apr 20, 2025 am 12:06 AM

Redis在現實世界中的應用包括:1.作為緩存系統加速數據庫查詢,2.存儲Web應用的會話數據,3.實現實時排行榜,4.作為消息隊列簡化消息傳遞。 Redis的多功能性和高性能使其在這些場景中大放異彩。

REDIS:探索其功能和功能REDIS:探索其功能和功能Apr 19, 2025 am 12:04 AM

Redis脫穎而出是因為其高速、多功能性和豐富的數據結構。 1)Redis支持字符串、列表、集合、散列和有序集合等數據結構。 2)它通過內存存儲數據,支持RDB和AOF持久化。 3)從Redis6.0開始引入多線程處理I/O操作,提升了高並發場景下的性能。

See all articles

熱AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover

AI Clothes Remover

用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool

Undress AI Tool

免費脫衣圖片

Clothoff.io

Clothoff.io

AI脫衣器

Video Face Swap

Video Face Swap

使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱工具

mPDF

mPDF

mPDF是一個PHP庫,可以從UTF-8編碼的HTML產生PDF檔案。原作者Ian Back編寫mPDF以從他的網站上「即時」輸出PDF文件,並處理不同的語言。與原始腳本如HTML2FPDF相比,它的速度較慢,並且在使用Unicode字體時產生的檔案較大,但支援CSS樣式等,並進行了大量增強。支援幾乎所有語言,包括RTL(阿拉伯語和希伯來語)和CJK(中日韓)。支援嵌套的區塊級元素(如P、DIV),

SecLists

SecLists

SecLists是最終安全測試人員的伙伴。它是一個包含各種類型清單的集合,這些清單在安全評估過程中經常使用,而且都在一個地方。 SecLists透過方便地提供安全測試人員可能需要的所有列表,幫助提高安全測試的效率和生產力。清單類型包括使用者名稱、密碼、URL、模糊測試有效載荷、敏感資料模式、Web shell等等。測試人員只需將此儲存庫拉到新的測試機上,他就可以存取所需的每種類型的清單。

VSCode Windows 64位元 下載

VSCode Windows 64位元 下載

微軟推出的免費、功能強大的一款IDE編輯器

SublimeText3漢化版

SublimeText3漢化版

中文版,非常好用

WebStorm Mac版

WebStorm Mac版

好用的JavaScript開發工具