Redis事务
重要 :Redis单条命令保证原子性,但是事务不保证原子性,也就是说原子性不是Redis事务的特性
Redis事务本质: 一组命令的集合,一个事务所有的命令都会被序列化,会先将命令放入一个队列中,然后一次性按顺序执行,所有的命令在事务中并没有直接被执行,只有发起执行命令时才会被执行;
- 一次性
- 顺序性
- 排他性
Redis事务的基本使用
multi:开启一个事务exec:执行事务discard:放弃事务
如果命令发生了错误怎么办?
这里会有两种错误类型,我们类比Java异常:
编译时异常: 也就是命令错了,这个时候事务中所有的命令都不会被执行;
运行时异常: 就好比在Java代码中写了一个1/0,这里我们就举一个让字符串自增一的错误:
上图中虽然自增一报错了,但是其余的命令还是正常执行;
Redis实现乐观锁
悲观锁: 认为什么时候都会出问题,无论做什么都加锁,影响效率;
乐观锁: 认为什么时候都不会出问题,所以不会上锁,更新数据的时候判断一下在此期间是否有人修改过数据;
Redis中利用watch命令来监视一个key来实现乐观锁;
我们还是以最经典的转账来说明:
现在有a,b两个人,a给b转账1元;
执行到这里时我们开启另一个终端,给a充值100元
由于我们watch监测了a,b的值,a的值此时发生了改变,所以事务会失败;