事务:可以一次执行多个命令,本质是一组命令的集合,一个事务中的所有命令都会序列化,按顺序地串行化执行而不会被其他命令插入,不许加塞;
一个队列中,一次性,顺序性,排他性地执行一系列命令
MULTI:开启事务
EXEC:调用执行命令
DISCARD:取消事务
事务的三阶段:
开启:MULTI开始一个事务;
入队:将多个命令入队到事务中,接到这些命令并不会立即执行,而是放到等待执行的事务队列里面;
执行:EXEC命令触发事务;
redis中事务的三个特点:
(1)正常执行时
(2)放弃事务DISCARD,事务中的命令就都无法执行了
(3)在事务开启后,在将各条命令入QUEUED的过程中,执行命令就出错了,则会导致整个事务中的命令都不会执行
(4)在事务开启后,在入QUEUED的过程中,执行命令未报错(但这条命令是错误的),但是在调用EXEC后,才报错;此时,事务中的命令该怎么执行就怎么执行,不会像(2)中那样都不执行了;
由(3)(4)也可知,redis是部分支持原子性的;
(5)watch监控
watch key[key…]:监视一个或多个key;如果在事务执行之前这个(或这些)key被其他命令所改动,那么事务将被打断;
unwatch:取消watch命令对所有key的监视
中途修改了balance:
由于中途修改了balance,所以下面再次执行事务时,就会失败: