Redis学习笔记(三)-----Redis事务

Redis事务

重要 :Redis单条命令保证原子性,但是事务不保证原子性,也就是说原子性不是Redis事务的特性


Redis事务本质: 一组命令的集合,一个事务所有的命令都会被序列化,会先将命令放入一个队列中,然后一次性按顺序执行,所有的命令在事务中并没有直接被执行,只有发起执行命令时才会被执行;

  • 一次性
  • 顺序性
  • 排他性

Redis事务的基本使用

Redis学习笔记(三)-----Redis事务

multi:开启一个事务
exec:执行事务
discard:放弃事务


如果命令发生了错误怎么办?
这里会有两种错误类型,我们类比Java异常:
编译时异常: 也就是命令错了,这个时候事务中所有的命令都不会被执行;
Redis学习笔记(三)-----Redis事务
运行时异常: 就好比在Java代码中写了一个1/0,这里我们就举一个让字符串自增一的错误:

Redis学习笔记(三)-----Redis事务
上图中虽然自增一报错了,但是其余的命令还是正常执行;

Redis实现乐观锁

悲观锁: 认为什么时候都会出问题,无论做什么都加锁,影响效率;
乐观锁: 认为什么时候都不会出问题,所以不会上锁,更新数据的时候判断一下在此期间是否有人修改过数据;


Redis中利用watch命令来监视一个key来实现乐观锁;
我们还是以最经典的转账来说明:
现在有a,b两个人,ab转账1元;
Redis学习笔记(三)-----Redis事务
执行到这里时我们开启另一个终端,给a充值100元
Redis学习笔记(三)-----Redis事务
由于我们watch监测了ab的值,a的值此时发生了改变,所以事务会失败;
Redis学习笔记(三)-----Redis事务