事务

本文介绍了Redis的简单事务机制,包括multi和exec命令的基本用法,以及如何通过watch命令解决并发修改问题。

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

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

正常流程的事务

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

clipboard

异常流程的事务

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

clipboard[1]

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

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

Watch命令的使用

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

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

clipboard[2]

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

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值