Redis基本的事务操作
1、Redis中事务的本质:一组命令的集合。
一个事务中的所有命令都会被序列化,在事务执行的过程中,会按照顺序执行。
Redis中的事务没有隔离级别的概念,不存在脏读,幻读等一系列情况。
单个 Redis 命令的执行是原子性的,即一个命令那么执行成功,要么执行失败。
但 Redis 没有在事务上增加任何维持原子性的机制,所以Redis 事务的执行并不是原子性的。
事务可以理解为一个打包的批量执行脚本,但批量指令并非原子化的操作,中间某条指令的失败不会导致前面已做指令的回滚,也不会造成后续的指令不做。
2、Redis 事务可以一次执行多个命令, 并且带有以下三个重要的保证:
(1)批量操作在发送 EXEC 命令前被放入队列缓存。
(2)收到 EXEC 命令后进入事务执行,事务中任意命令执行失败,其余的命令依然被执行。
(3)在事务执行过程,其他客户端提交的命令请求不会插入到事务执行命令序列中。
3、一个事务从开始到执行会经历以下三个阶段:
开始事务(multi)
命令入队(多个命令存入队列)
执行事务(exec)
(1)事务的三阶段: