zoukankan      html  css  js  c++  java
  • redis事务

    Redis 事务

    Redis 事务可以一次执行多个命令, 并且带有以下两个重要的保证:

    • 事务是一个单独的隔离操作:事务中的所有命令都会序列化、按顺序地执行。事务在执行的过程中,不会被其他客户端发送来的命令请求所打断。
    • 事务是一个原子操作:事务中的命令要么全部被执行,要么全部都不执行。

    一个事务从开始到执行会经历以下三个阶段:

    • 开始事务。
    • 命令入队。
    • 执行事务。

    Redis 事务命令

    MULTI:

    用于标记事务块的开始。Redis会将后续的命令逐个放入队列中,然后才能使用EXEC命令原子化地执行这个命令序列。

    EXEC:

    在一个事务中执行所有先前放入队列的命令,然后恢复正常的连接状态。

    当使用WATCH命令时,只有当受监控的键没有被修改时,EXEC命令才会执行事务中的命令,这种方式利用了检查再设置(CAS)的机制。

    DISCARD:

    清除所有先前在一个事务中放入队列的命令,然后恢复正常的连接状态。

    如果使用了WATCH命令,那么DISCARD命令就会将当前连接监控的所有键取消监控。

    WATCH:

    当某个事务需要按条件执行时,就要使用这个命令将给定的键设置为受监控的。

    这个命令的运行格式如下所示 :WATCH key [key ...]

    UNWATCH:

    清除所有先前为一个事务监控的键。

    如果你调用了EXEC或DISCARD命令,那么就不需要手动调用UNWATCH命令。

    redis的事务实现是如此简单,当然会存在一些问题。第一个问题是redis只能保证事务的每个命令连续执行,但是如果事务中的一个命令失败了,并不回滚其他命令,比如使用的命令类型不匹配。

    redis> set a 5
    OK
    redis> lpush b 5
    (integer) 1
    redis> set c 5
    OK
    redis> multi
    OK
    redis> incr a
    QUEUED
    redis> incr b
    QUEUED
    redis> incr c
    QUEUED
    redis> exec
    1. (integer) 6
    2. (error) ERR Operation against a key holding the wrong kind of value
    3. (integer) 6
    可以看到虽然incr b失败了,但是其他两个命令还是执行了。
    最 后一个十分罕见的问题是 当事务的执行过程中,如果redis意外的挂了。很遗憾只有部分命令执行了,后面的也就被丢弃了。当然如果我们使用的append-only file方式持久化,redis会用单个write操作写入整个事务内容。即是是这种方式还是有可能只部分写入了事务到磁盘。发生部分写入事务的情况 下,redis重启时会检测到这种情况,然后失败退出。可以使用redis-check-aof工具进行修复,修复会删除部分写入的事务内容。修复完后就 能够重新启动了。
  • 相关阅读:
    c++笔记--数组对象、vector对象和构造函数
    马加爵之歌
    周末有同学要来
    IQ
    [转]JavaScript中typeof 讲解
    【转】JS兼容Firefox
    firefox与ie 的javascript区别
    关于委托(转)
    经典常用的javascript代码收藏
    关于DataList使用DropDownList的分页实现 技巧实例源码
  • 原文地址:https://www.cnblogs.com/ryjJava/p/8047873.html
Copyright © 2011-2022 走看看