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

![clipboard[1] clipboard[1]](https://i-blog.csdnimg.cn/blog_migrate/c9c015dac1b5dec49932afaed889c1c6.png)
![clipboard[2] clipboard[2]](https://i-blog.csdnimg.cn/blog_migrate/a0df90b4bbdba0d43b1153284e5d6ba3.png)
170万+

被折叠的 条评论
为什么被折叠?



