-
multi 开启一个事务,返回总是ok。
multi执行后,用户可以发布多条命令,这些命令不会马上执行,而是被redis放到一个队列里,直到exec命令执行后队列里的所有命令才会被执行。
-
exec 负责触发执行事务队列中的所有命令。要么所有的命令都得到执行,要么所有的命令都不执行。
例:原子的增加两个键
> MULTI
OK
> INCR foo
QUEUED
> INCR bar
QUEUED
> EXEC
1) (integer) 1
2) (integer) 1
事务中的错误
- exec执行之前的错误
比如:参数不对,命令不对等。
- 在Redis 2.6.5以后会对入队失败的操作进行记录,在exec执行时拒绝执行并放弃该事务。2.6.5以前会执行入队成功的事务,入队不成功的忽略。
- exec执行之后的错误
exec之后的错误没有进行特殊处理,即使有错误发生事务中其它正确的也会继续执行。
- redis中不支持回滚
-
discard 命令执行后会清空事务队列,并退出事务。
> SET foo 1
OK
> MULTI
OK
> INCR foo
QUEUED
> DISCARD
OK
> GET foo
"1"
-
watch 为redis事务提供CAS(check-and-set)行为。监视一个或多个key,事务只能在这些没有修改的情况下执行,否则事务不执行。watch命令开启监视直到exec命令结束或者使用unwatch取消监视
#监视多个key
> WATCH key1 key2 key3
OK
#用法
> WATCH mykey
val = GET mykey
val = val + 1
> MULTI
> SET mykey $val
> EXEC
网友评论