Redis目前對事務的支持仍是比較簡單,Redis能保證一個Client發起的事務中的命令能夠連續執行,而中間不會插入其餘Client的命令;當一個Client在鏈接中發起一個multi命令的時候,這個鏈接會進入事務上下文,而鏈接後續的命令不會當即執行,而是先放到一個隊列中,當執行exec命令的時候,redis會順序的執行該隊列中的全部命令。redis
Redis事務涉及的命令關鍵字:MULTI 進入一個事務上下文,EXEC 執行事務 ,DISCARD 回滾事務 , Watch 事務樂觀鎖sql
在SQLServer 或 Mysql 當中的事務(當事務中操做出現錯誤的時候,會徹底回滾事務)。可是在 Redis 中會有些不同。spa
能夠從下面命令執行過程當中看到:隊列
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須要改進的地方。字符串
事務樂觀鎖get
watch 命令會監視給定的key ,當exec時候,若是監視的key發生過變化,則整個事務失敗。io
當有多個Session時,Seesion1 首先開啓事務,對 age 賦值爲 100,此時事務暫時未被Exec。Session2使用非事務方式對 age 賦值爲 120,賦值完成。而後 Session1執行 Exec命令。當一個key被加上樂觀鎖的時候,該事務會執行失敗。error
Session1:di
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 命令都會清除鏈接中的監視