事务

redis只实现了简单版的事务机制,毕竟它追求的是简单,快速和高效。

下面一起来看下几种情形。

正常流程的事务

使用命令multi和exec就可以实现。multi生成一个事务,exec来执行接受到的命令。如下图所示。

clipboard

异常流程的事务

上面我们一次执行了三条命令,那假如其中一条命令执行时报错会怎么样,redis会rollback吗?我们来看一下。

clipboard[1]

所以,redis并没有实现rollback回滚机制,有人会问,这样的怎么算事务呢,都不能保证事务的原子性。

但是redis帮我们实现了,多人同时修改一个key的值的并发情形,可以使用watch命令实现,接着往下看。

Watch命令的使用

首先看一下watch命令的官方解释:监视一个(或多个) key ,如果在事务执行之前这个(或这些) key 被其他命令所改动,那么事务将被打断。

下面我们就来模拟下,如下图所示。

clipboard[2]

可以看到,exec后执行失败。

原文地址:https://www.cnblogs.com/mcgrady/p/5082888.html