redis只实现了简单版的事务机制,毕竟它追求的是简单,快速和高效。
下面一起来看下几种情形。
正常流程的事务
使用命令multi和exec就可以实现。multi生成一个事务,exec来执行接受到的命令。如下图所示。
异常流程的事务
上面我们一次执行了三条命令,那假如其中一条命令执行时报错会怎么样,redis会rollback吗?我们来看一下。
所以,redis并没有实现rollback回滚机制,有人会问,这样的怎么算事务呢,都不能保证事务的原子性。
但是redis帮我们实现了,多人同时修改一个key的值的并发情形,可以使用watch命令实现,接着往下看。
Watch命令的使用
首先看一下watch命令的官方解释:监视一个(或多个) key ,如果在事务执行之前这个(或这些) key 被其他命令所改动,那么事务将被打断。
下面我们就来模拟下,如下图所示。
可以看到,exec后执行失败。