• 技术文章 >数据库 >Redis

    redis事务有什么用

    藏色散人藏色散人2019-06-19 11:17:03原创1330

    Redis事务

    MULTI, EXEC, DISCARD and WATCH 是Redis事务的基础。用来显式开启并控制一个事务,它们允许在一个步骤中执行一组命令。并提供两个重要的保证:

    ● 事务中的所有命令都会被序列化并按顺序执行。在执行Redis事务的过程中,不会出现由另一个客户端发出的请求。这保证 命令队列 作为一个单独的原子操作被执行。

    ● 队列中的命令要么全部被处理,要么全部被忽略。EXEC命令触发事务中所有命令的执行,因此,当客户端在事务上下文中失去与服务器的连接,

    ● 如果发生在调用MULTI命令之前,则不执行任何commands;

    ● 如果在此之前EXEC命令被调用,则所有的commands都被执行。

    同时,redis使用AOF(append-only file),使用一个额外的write操作将事务写入磁盘。如果发生宕机,进程奔溃等情况,可以使用redis-check-aof tool 修复append-only file,使服务正常启动,并恢复部分操作。(推荐:《Redis视频教程》)

    用法

    使用MULTI命令显式开启Redis事务。 该命令总是以OK回应。此时用户可以发出多个命令,Redis不会执行这些命令,而是将它们排队。EXEC被调用后,所有的命令都会被执行。而调用DISCARD可以清除事务中的commands队列并退出事务。

    以下示例以原子方式,递增键foo和bar。

    >MULTI
    OK
    >INCR foo
    QUEUED
    >INCR bar
    QUEUED
    >EXEC
    1)(整数)1
    2)(整数)1

    从上面的命令执行中可以看出,EXEC返回一个数组,其中每个元素都是事务中单个命令的返回结果,而且顺序与命令的发出顺序相同。

    当Redis连接处于MULTI请求的上下文中时,所有命令将以字符串QUEUED(从Redis协议的角度作为状态回复发送)作为回复,并在命令队列中排队。只有EXEC被调用时,排队的命令才会被执行,此时才会有真正的返回结果。

    以上就是redis事务有什么用的详细内容,更多请关注php中文网其它相关文章!

    声明:本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn核实处理。
    专题推荐:redis事务
    上一篇:redis用在什么地方 下一篇:redis是干什么的

    相关文章推荐

    • Redis事务处理• MySQL和Redis事务的比较(图文)• Linux安装Redis教程• redis用在什么地方

    全部评论我要评论

  • 取消发布评论发送
  • 1/1

    PHP中文网