Reids 单条命令保存有原子性,但是事务并不保证原子性。与MySQL完全不同

Redis 事务的本质:一组命令的集合,一个事务中所有的命令都会被序列化,命令会按照顺序执行。
Redis 事务具有一次性,顺序性,排他性
Redis 事务并没有隔离级别的概念!所有的命令并没有直接执行而是先被序列化到一个队列中。

Redis 事务:
1.开启事务(multi)
2.命令入队
3.执行事务(exec)
取消事务(discard)

如果执行事务过程中出现编译性异常,则该事务所有的命令都不会执行。如果事务队列出现语法错误,则正确命令可执行,错误命令抛出异常

命令watch可实现乐观锁,如果事务发生异常,先解锁再获取新的乐观锁再执行事务。
由于乐观锁的不上锁特性,所以在性能方面要比悲观锁好,比较适合用在DB的读大于写的业务场景。