一、redis事务能够依次执行多个命令,而且带有如下三个重要的保证:redis
- 批量操做在发送exec命令前被放入队列缓存。
- 收到exec命令后进入事务执行,事务中任意命令执行失败,其他的命令依然被执行。
- 在事务执行过程,其余客户端提交的命令请求不会插入到事务执行命令序列中。
二、一个事务从开始到执行会经历一下三个阶段:缓存
- 开始事务
- 命令入队
- 执行事务
三、事务处理相关命令spa
- 命令名称:multi
- 语法:multi
- 功能:
- 返回值:
- 命令名称:exec
- 语法:exec
- 功能:
- 返回值:
- 事务块内全部命令的返回值,按命令执行的前后顺序排列。
- 当操做被打断时,返回空值nil。
- 命令名称:discard
- 语法:discard
- 功能:
- 返回值:
- 命令名称:watch
- 语法:watch key [key……]
- 功能:
- 监视一个(或多个)key,若是在事务执行以前这个(或这些)key被其余命令所改动,那么事务将被打断。
- 返回值:
- 命令名称:unwatch
- 语法:unwatch
- 功能:
- 取消watch命令对全部key的监视。
- 若是在执行watch命令以后,exec命令或discard命令先被执行了的话,那么久不须要再执行unwatch了
- 返回值:老是返回OK