一.Redis自带事务机制
Redis事务通过MULTI 、 EXEC 、 DISCARD 、WATCH和UNWATCH命令操作,过程如下:
通过MULTI 开启事务,然后添加任意条命令到队列,通过EXEC 执行队列命令,通过DISCARD 放弃事务,通过WATCH提供锁机制,通过UNWATCH取消对key的监控。
例1:普通用法
127.0.0.1:6379> multi
OK
127.0.0.1:6379> incr aaa
QUEUED
127.0.0.1:6379> incr bbb
QUEUED
127.0.0.1:6379> exec
1) (integer) 1
2) (integer) 1
127.0.0.1:6379> set aaa 1
OK
127.0.0.1:6379> multi
OK
127.0.0.1:6379> incr aaa
QUEUED
127.0.0.1:6379> discard
OK
127.0.0.1:6379> get aaa
"1"
127.0.0.1:6379> watch aaa
OK
127.0.0.1:6379> set aaa 100
OK
127.0.0.1:6379> multi
OK
127.0.0.1:6379> set aaa 200
QUEUED
127.0.0.1:6379> exec
(nil)
127.0.0.1:6379> get aaa
"100"
127.0.0.1:6379> multi
OK
127.0.0.1:6379> incr b
QUEUED
127.0.0.1:6379> set c 1 2
QUEUED
127.0.0.1:6379> exec
1) (integer) 1
2) (error) ERR syntax error
127.0.0.1:6379> get b
"1"
127.0.0.1:6379> get c
(nil)
127.0.0.1:6379> eval "return redis.call('set',KEYS[1],'bar')" 1 foo
OK
127.0.0.1:6379> get foo
"bar"