Redis的事务

    xiaoxiao2022-11-07  18

    简介


    Redis事务可以一次执行多个命令(允许在一个单独的步骤中执行一组命令),按顺序地串行化执行,执行过程中不会被其他命令插入,不许加塞。

     

    在输入 MULTI 命令开始,输入的命令会依次进入命令队列,但不会执行。

    输入 EXEC 命令后进入事务执行,事务中任意命令执行失败,其余命令依然执行。

    在事务执行过程中,其他客户端提交的命令请求不会插入到事务执行命令序列中。

     

     

    Redis事务命令


    下面是Redis事务的相关命令

    命令

    描述

    DISCARD

    取消事务,放弃事务块内所有命令

    EXEC

    执行所有事务块内的命令

    MULTI

    标记一个事务块的开始

     

     

    事务的错误处理


    如果执行的某个命令执行出错,只有出错的命令不会被执行,其他命令都会被执行,不会回滚。

     

    队列中某个命令出现了报告错误,执行时整个的队列都会被取消。

    下面的例子就是因为错误的命令而导致出现了报告错误。

     

     

    事务的WATCH


    WATCH key [key...]

    监视一个或多个key,如果在事务执行之前,这个key被其他命令所改动,那么事务将被打断。

     

    例如:某一帐户在一事务内进行操作,在提交事务前,另一个进程对该帐户进行操作,那么该事务将被打断。

     

     

    事务的UNWATCH


    Redis的UNWATCH命令用于取消WATCH 命令对所有key的监视。

    如果在执行WATCH命令之后,EXEC命令或DISCARD命令先被执行的话,就不需要在执行UNWATCH命令了。

    最新回复(0)