zoukankan      html  css  js  c++  java
  • 事务

    redis只实现了简单版的事务机制,毕竟它追求的是简单,快速和高效。

    下面一起来看下几种情形。

    正常流程的事务

    使用命令multi和exec就可以实现。multi生成一个事务,exec来执行接受到的命令。如下图所示。

    clipboard

    异常流程的事务

    上面我们一次执行了三条命令,那假如其中一条命令执行时报错会怎么样,redis会rollback吗?我们来看一下。

    clipboard[1]

    所以,redis并没有实现rollback回滚机制,有人会问,这样的怎么算事务呢,都不能保证事务的原子性。

    但是redis帮我们实现了,多人同时修改一个key的值的并发情形,可以使用watch命令实现,接着往下看。

    Watch命令的使用

    首先看一下watch命令的官方解释:监视一个(或多个) key ,如果在事务执行之前这个(或这些) key 被其他命令所改动,那么事务将被打断。

    下面我们就来模拟下,如下图所示。

    clipboard[2]

    可以看到,exec后执行失败。

  • 相关阅读:
    典型格雷码-数学规律
    合并两个有序数组
    从fragment跳转到Activity
    fragment如何findviewby
    布局和位置
    preferencefragment
    AndroidStudio导入support-v13
    一些属性作用
    菜单menu
    ActionBar
  • 原文地址:https://www.cnblogs.com/mcgrady/p/5082888.html
Copyright © 2011-2022 走看看