四. Redis交易處理

來源:互聯網
上載者:User

標籤:

Redis目前對事務的支援還是比較簡單,Redis能保證一個Client發起的事務中的命令可以連續執行,而中間不會插入其他Client的命令;當一個Client在串連中發起一個multi命令的時候,這個串連會進入事務上下文,而串連後續的命令不會立即執行,而是先放到一個隊列中,當執行exec命令的時候,redis會順序的執行該隊列中的所有命令。

 

Redis事務涉及的命令關鍵字:MULTI 進入一個事務上下文,EXEC 執行事務 ,DISCARD 復原事務 , Watch 事務樂觀鎖

 

在SQLServer 或 Mysql 當中的事務(當事務中操作出現錯誤的時候,會完全復原事務)。但是在 Redis 中會有些不一樣。

可以從下面命令執行過程中看到:

127.0.0.1:6379> set age 10
OK
127.0.0.1:6379> set name hexu
OK
127.0.0.1:6379> multi
OK
127.0.0.1:6379> incr age
QUEUED
127.0.0.1:6379> incr name
QUEUED
127.0.0.1:6379> exec
1) (integer) 11
2) (error) ERR value is not an integer or out of range
127.0.0.1:6379> get age
"11"
127.0.0.1:6379> get name
"hexu"

 

key["age"]是一個int,key["name"]是一個字串,當我們通過incr命令遞增age和name的時候,name出現錯誤,最後我們執行exec命令,age的結果沒有復原。這就redis需要改進的地方。

 

事務樂觀鎖

watch 命令會監視給定的key ,當exec時候,如果監視的key發生過變化,則整個事務失敗。

當有多個Session時,Seesion1 首先開啟事務,對 age 賦值為 100,此時事務暫時未被Exec。Session2使用非事務方式對 age 賦值為 120,賦值完成。然後 Session1執行 Exec命令。當一個key被加上樂觀鎖的時候,該事務會執行失敗。

Session1:

127.0.0.1:6379> WATCH age      第一步
OK
127.0.0.1:6379> MULTI          第二步
OK
127.0.0.1:6379> set age 100      第三步
QUEUED
127.0.0.1:6379> EXEC          第五步
(nil)

Session2:

127.0.0.1:6379> set age 120      第四步
OK

使用 EXEC,DiSCARD,UNWATCH 命令都會清除串連中的監視

 

四. Redis交易處理

相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.