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
的值此时发生了改变,所以事务会失败;