注:Redis没有回滚(所以需要配合 watch 一起使用)
Redis的事务:一次事务操作,改成功的成功,该失败的失败。
先开启事务,执行一些列的命令,但是命令不会立即执行,会被放在一个队列中,如果你执行事务,那么这个队列中的命令全部执行,如果取消了事务,一个队列中的命令全部作废。
-
开启事务:multi
-
输入要执行的命令:被放入到一个队列中
-
执行事务:exec
-
取消事务:discard
Redis的事务想发挥功能,需要配置watch监听机制
在开启事务之前,先通过watch命令去监听一个或多个key,在开启事务之后,如果有其他客户端修改了我监听的key,事务会自动取消。
例:
1)我的客户端开起监听m:
2)其它客户端修改了m
3)我的客户端监听到到m被其他客户端修改了所以我的客户端再去修改m会修改失败
4)最后获取到的m key 的值是被其它客户端修改后的值,也就是为2
如果执行了事务,或者取消了事务,watch监听自动消除,一般不需要手动执行unwatch。