简介
Redis事务可以一次执行多个命令(允许在一个单独的步骤中执行一组命令),按顺序地串行化执行,执行过程中不会被其他命令插入,不许加塞。
在输入 MULTI 命令开始,输入的命令会依次进入命令队列,但不会执行。
输入 EXEC 命令后进入事务执行,事务中任意命令执行失败,其余命令依然执行。
在事务执行过程中,其他客户端提交的命令请求不会插入到事务执行命令序列中。
Redis事务命令
下面是Redis事务的相关命令
命令
描述
DISCARD
取消事务,放弃事务块内所有命令
EXEC
执行所有事务块内的命令
MULTI
标记一个事务块的开始
事务的错误处理
如果执行的某个命令执行出错,只有出错的命令不会被执行,其他命令都会被执行,不会回滚。
队列中某个命令出现了报告错误,执行时整个的队列都会被取消。
下面的例子就是因为错误的命令而导致出现了报告错误。
事务的WATCH
WATCH key [key...]
监视一个或多个key,如果在事务执行之前,这个key被其他命令所改动,那么事务将被打断。
例如:某一帐户在一事务内进行操作,在提交事务前,另一个进程对该帐户进行操作,那么该事务将被打断。
事务的UNWATCH
Redis的UNWATCH命令用于取消WATCH 命令对所有key的监视。
如果在执行WATCH命令之后,EXEC命令或DISCARD命令先被执行的话,就不需要在执行UNWATCH命令了。