Redis事务

Redis 事务可以一次执行多个命令, 并且带有以下两个重要的保证:

事务是一个单独的隔离操作:事务中的所有命令都会序列化、按顺序地执行。事务在执行的过程中,不会被其他客户端发送来的命令请求所打断。
事务是一个原子操作:事务中的命令要么全部被执行,要么全部都不执行。

MULTI
MULTI 命令用于开启一个事务,它总是返回 OK 。 MULTI 执行之后, 客户端可以继续向服务器发送任意多条命令, 这些命令不会立即被执行, 而是被放到一个队列中, 当 EXEC命令被调用时, 所有队列中的命令才会被执行。另一方面, 通过调用 DISCARD , 客户端可以清空事务队列, 并放弃执行事务。

EXEC
一次性执行事务队列中的命令

DISCARD
取消事务执行

WATCH Key1 [Key2 Key2]
监视一个或多个键值,如果在事务中监视了这些键,在事务外修改了这个键值,事务会终止

UNWATCH
取消所有键值的监视

事务正常操作
Redis事务

放弃事务

Redis事务
事务中执行命令出错,全部回滚
Redis事务
适合命令本身出错场景

事务中命令正确,但修改数据出错,事务不回滚
Redis事务
键d2存放的是字符串,自增命令出错,但其他的命令不回滚。

在其他会话中修改事务监视的变量
Redis事务

Redis事务特性Redis事务