Redis事务有四个操作命令
Multi 开启事务
Exec 提交事务
Watch 可以监听一个或多个key,在提交的时候看与之前是否发生变化,如果发生了变化则不提交,没有发生变化则提交(原理就类似于乐观锁,给每次修改都加上了一个版本号)
Discard 取消事务
Redis事务没有回滚,只有取消事务
下面来看代码演示
大家可以开启两个redis客户端界面
大家可以看到右手边的客户端是提交了事务然后我们再来把左手边的客户端提交事务
会发现在两边客户端来获取这个key的值都是左手边客户端提交的事务的值
再来看Watch
会发现在加了Watch监听name后左手边的客户端开启了事务修改了name值但是未提交,然后右手边的客户端开启事务也对name做了修改然后提交,这时再到左手边来提交则会发现提交失败,原因就是因为发现和之前设置的版本不一致
下面再来看看Discard取消事务
可以看到提交事务失败
再来说redis为什么只有取消事务而没有回滚
原因很简单,redis和mysql都有事务,mysql有回滚,redis没有回滚
mysql开启事务时会对这条数据进行行锁,以防止其他人在我事务还没提交的时候进行修改
回滚其实有两步,一是把事务取消,二把对这条数据的行锁释放掉
而redis没有行锁这个概念,那就只用取消掉事务即可,所以这也是为什么redis只有取消事务而没有回滚的原因
总结
Multi缺点:谁后提交事务谁起效,所以才有Watch来解决这个问题