1,概论

      事物这东西相信大家都不陌生吧,在学习Spring,Mybatis等框架中,

      只要是涉及到数据存储和修改的,都会有事物的存在,

      废话就不多说了下面我们来简单的介绍下Redis事物以及锁。


2,Redis事物简介?

    Redis 事务可以一次执行多个命令, 并且我们来了解几个重要的知识点:

  1. 开启事物后,一切命令都会放入队列当中,当执行EXEC以后才会挨个执行。
  2. 当执行EXEC命令后,如果队列中有命令出错,那么此队列中的全部命令将不会执行(这里有两种可能),后面会举例介绍。
  3. 当事物执行以后,其他客户端提交的命令请求不会插入到事务执行命令序列中。

  事物执行的三个阶段:

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

3,Redis事物(Transaction)命令?

DISCARD 取消事务,放弃执行事务块内的所有命令。
EXEC 执行所有事务块内的命令。
MULTI 开启事物
UNWATCH 取消 WATCH 命令对所有 key 的监视。
WATCH key 监视一个(或多个) key ,如果在事务执行之前这个(或这些) key 被其他命令所改动,那么事务将被打断。

4,Redis事物使用?

  下面我们来通过几个例子认识下

  1.正常执行

  

  2.放弃事物

     放弃事物,队列里面的命令将不会执行。

  

 3.全体连坐

   一个命令出错,队列中的全部命令将不会执行。

  

  

  4.冤头债主

    这个例子跟上面的差不多,只不过这个例子是执行了以后再报错,他两不同的地方就是

    上面是先知道错误,这个是执行后才知道错误了,举个例子吧,

    比如 我要让我的Redis数据数值增一操作,我在控制台执行命令,INCR key 当事物还没执行的时候,

    也就是说这个命令还在队列中,还没执行,它是不知道我这个key到底是个数值还是个字符串,

    假设key不是个数值类型那么当执行事物后,这条命令将会报错,其他的命令正常执行。

    

  5.WATCH监控

      在了解WATCH监控前我们先来聊聊乐观锁和悲欢锁,

   ①悲观锁:我很悲观,我觉得我每次去拿数据的时候都会被人修改,所以我每次拿数据的时候我就会上锁,

       别人想拿这个数据的时候就会block,直到别人拿到锁。传统的关系型数据库里面就会用到很多这种机制,

       比如 行锁,表锁,读锁,写锁等,都是在操作前加上锁,防止多人修改同一条数据。这样的话就成功提高了数据的一致性,降低了并发性。

   ②乐观锁:我很乐观,我觉得我每次去拿数据的时候别人都不会修改,所以不会上锁,但是我在更新数据的时候,

        我就会判断一下,有没有别人去更新这个数据,这里我们可以使用版本号等机制来实现判断。

        乐观锁适用于多读的应用类型,这样可以提高吞吐量和并发性。

                乐观锁策略:提交版本必须大于记录当前版本才能更新数据

   下面来看看WATCH怎么使用的

  一,无加塞篡改

    我这里就拿个花呗额度来举例,假设我的balance为余额,arrears为欠下的余额,下面这张图为

    无加塞篡改,先监控在开启multi,保证两笔金额变动在同一事物内,一起执行。

    

  二,有加塞篡改

      类似于我在修改这个数据的时候,被其他用户已经修改了,已经被加上锁了,我自己就修改不了了,要等被人修改完才能够修改,这跟上面的乐观锁很相似,

        我开启两个控制台,一个用来正常操作,一个用来中途篡改数据。

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

      下面我们来看图.

      

我还没执行这些命令之前我根本不知道我的数据已经在被人修改了,当我要修改数据的时候已经被人先改了。

这时候我们UNWATCH命令就派上用场了,相当于当我修改数据的时候我就把锁加上,修改完成后就把锁解开,让下一个人继续修改数据,

取消 WATCH 命令对所有 key 的监视,一旦我们执行EXEC以后所有监控锁都会被取消掉。

下面我们来看图


  5,结尾

      后面还会更新如何使用RedisTemplate来操作Redis命令,如何解决Redis穿透/雪崩等。

      文章就写到这里了,如果文章有需要改进的地方请大佬们在评论区里留言,谢谢点评。

Redis 事物、悲观、乐观锁 (详细)的更多相关文章

  1. 五分钟学会悲观乐观锁-java vs mysql vs redis三种实现

    1 悲观锁乐观锁简介 乐观锁( Optimistic Locking ) 相对悲观锁而言,乐观锁假设认为数据一般情况下不会造成冲突,所以在数据进行提交更新的时候,才会正式对数据的冲突与否进行检测,如果 ...

  2. php+redis 学习 三 乐观锁

    <?php header('content-type:text/html;chaeset=utf-8'); /** * redis实战 * * 实现乐观锁机制 * * @example php ...

  3. redis事务和乐观锁

    1 MULTI/EXEC 执行本事务. MULTI set foo bar get foo set foo hello EXEC 在EXEC执行前,三条命令都放入队列中,然后EXEC触发执行.没有回滚 ...

  4. redis的hmset乐观锁的实现

    1.lua脚本(集成实现了乐观锁,hmset ,expire等) local key=KEYS[1]; local oldVerion=tonumber(ARGV[1]); local seconds ...

  5. Redis分布式锁----乐观锁的实现,以秒杀系统为例

    本文使用redis来实现乐观锁,并以秒杀系统为实例来讲解整个过程. 乐观锁      大多数是基于数据版本(version)的记录机制实现的.即为数据增加一个版本标识,在基于数据库表的版本解决方案中, ...

  6. 悲观锁 vs 乐观锁 vs Redis

    企业面对高并发场景采用的方案. 比如 产品抢购高并发时的超发现象. 1 悲观锁悲观锁 需要数据库本身提供支持(Oracle和MySQL都是支持的).实现细节:当前 数据库事务 读取到产品后, 就将目标 ...

  7. redis 事务(悲观锁和乐观锁)

    MULTI 开启事务,后续的命令会被加入到同一个事务中 事务中的操作会发送给客服端,但是不会立即执行,而是将操作放到了该事务对应的一个队列中,服务端返回QUEQUD EXEC 执行EXEC后,事务中的 ...

  8. 基于Django的乐观锁与悲观锁解决订单并发问题的一点浅见

    订单并发这个问题我想大家都是有一定认识的,这里我说一下我的一些浅见,我会尽可能的让大家了解如何解决这类问题. 在解释如何解决订单并发问题之前,需要先了解一下什么是数据库的事务.(我用的是mysql数据 ...

  9. Mysql悲观锁乐观锁区别与使用场景

    本人免费整理了Java高级资料,涵盖了Java.Redis.MongoDB.MySQL.Zookeeper.Spring Cloud.Dubbo高并发分布式等教程,一共30G,需要自己领取.传送门:h ...

随机推荐

  1. Python说文解字_杂谈04

    1. 鸭子类型: 当你看到一只鸟走来像鸭子,游泳起来像鸭子,叫起来也像鸭子,他么他就可以叫做鸭子.任何可迭代的对象.一样的方法,可以用可迭代的话,就可以迭代的组合打印.__getitem__可以塞到任 ...

  2. 微服务项目开发学成在线_Vue.js与Webpack

    Vue.js 1.Vue (读音 /vjuː/,类似于 view) 是一套用于构建用户界面的渐进式框架.自底向上逐层应用:作为渐进式框架要实现的目标就是方便项目增量开发. 渐进式框架:Progress ...

  3. MySQL和Java数据类型对照表

    Java MySQL数据类型对照 类型名称 显示长度 数据库类型 JAVA类型 JDBC类型索引(int) 描述             VARCHAR L+N VARCHAR java.lang.S ...

  4. WEB网站的favicon.ico的设置

    一.什么是favicon.ico Favicon是Favorites Icon的缩写,favicon.ico是指显示在浏览器收藏夹和地址栏网站网址前面的个性化图标,常被成为网页小图标.网站缩略图标或者 ...

  5. Jupyter notebook 和 Jupyter lab 的区别

    Jupyter Notebook Jupyter Notebook 是一个款以网页为基础的交互计算环境,可以创建Jupyter的文档,支持多种语言,包括Python, Julia, R等等.广泛用于数 ...

  6. Error:Execution failed for task ':app:preDebugAndroidTestBuild'. > Conflict with dependency

    Error : Execution failed for task ’ :app: preDebugAndroidTestBuild’.Conflict with dependency ‘com.an ...

  7. aop 实现原理

    aop 底层采用代理机制实现 接口 + 实现类 :spring 采用 jdk 的 动态代理 只有实现类:spring 采用 cglib 字节码增强 aop专业术语 1.target(目标) 需要被代理 ...

  8. 《深入理解java虚拟机》-目录结构

    第一部分 走进Java第1章 走进Java 第二部分 自动内存管理机制 第2章 Java内存区域与内存溢出异常2.1 概述2.2 运行时数据区域2.2.1 程序计数器2.2.2 java虚拟机栈2.2 ...

  9. Activity组件(三):通过对象实现信息添加及展示

    在对组件进行注册时,只注册了EditText,却忘记了Button,导致程序一直闪退 输入信息 点击添加 成功跳转页面,并将数据传递 User.java package com.example.reg ...

  10. android仿网易云音乐引导页、仿书旗小说Flutter版、ViewPager切换、爆炸菜单、风扇叶片效果等源码

    Android精选源码 复现网易云音乐引导页效果 高仿书旗小说 Flutter版,支持iOS.Android Android Srt和Ass字幕解析器 Material Design ViewPage ...