redis学习之redis事务

redis事务

redis的事务可以一次执行多个命令,本质是一组命令的集合。一个事务中所有的命令都会被序列化,按顺序串行执行且不会被其它命令插入。redis的事务分为3个阶段,分别是开始事务、命令入队、执行事务。

redis学习之redis事务

redis事务命令

multi:标记一个事务块的开始;
exec:执行事务块内的所有命令;
discard:取消事务,放弃执行事务内的所有命令;

redis事务如果在执行exec命令之前出现错误,服务器会对入队失败的命令进行记录,并在客户端调用exec命令执行事务的时候,拒绝执行并自动放弃这个事务。如果是在执行exec命令之后出现的错误,redis不会进行处理,事务会继续执行不会回滚,只有发生错误的命令不会执行成功,其它命令都会执行成功。

下面给出一个例子:
正常情况下,应该是这样的
redis学习之redis事务
如果在执行exec前出现了错误,可以看到redis拒绝执行这个事务。
redis学习之redis事务
如果在执行exec命令之后发生了错误,可以看到redis执行了事务,但是错误的命令没有执行,其它的的两个命令正常执行了。
redis学习之redis事务
取消事务例子,取消事务后其中的命令不会被执行。
redis学习之redis事务

watch:监视一个(或多个) key ,如果在事务执行之前这个(或这些) key 被其他命令所改动,那么事务将被打断,watch命令为redis事务提供CAS行为,如果至少一个被监视的键在EXEC执行之前被修改了,那么整个事务都会被取消。
unwatch:取消watch命令对所有key的监视;

watch命令举例
在执行exec命令前,打开另一个窗口,改变name的值,再执行exec命令,可以看到事务被取消了,获取name的值可以看到是在另一窗口中设置的值。
redis学习之redis事务

redis学习之redis事务

参考