码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • Redis 解决事务冲突之乐观锁和悲观锁


    文章目录

      • 一、Redis的事务冲突问题
      • 二、悲观锁
      • 三、悲观锁
      • 四、乐观锁的使用
      • 五、Redis 事务三特性

    一、Redis的事务冲突问题

    例子:
    比如说,3个人有你的账户:你有10000元
    一个人请求想给金额减 8000
    一个人请求想给金额减 5000
    一个人请求想给金额减 1000

    在这里插入图片描述

    二、悲观锁

    在这里插入图片描述
    悲观锁(Pessimistic Lock),顾名思义,就是很悲观,每次去拿数据的时候都认为别人会修改,所以每次在拿数据的时候都会上锁(上锁后不允许其他事务操作),这样别人想拿这个数据就会block直到它拿到锁。传统的关系型数据库里边就用到了很多这种锁机制,比如行锁,表锁等,读锁,写锁等,都是在做操作之前先上锁

    缺点是效率低,只能串行操作

    三、悲观锁

    在这里插入图片描述

    乐观锁(Optimistic Lock), 顾名思义,就是很乐观,每次去拿数据的时候都认为别人不会修改,所以不会上锁,所以所有人都可以拿到数据,但是在更新的时候会判断一下在此期间别人有没有去更新这个数据,可以使用版本号等机制。

    读数据的时候畅通无阻,更新数据的时候需要匹配读出来的数据的版本号和数据库内数据的版本号,一致则可修改,修改后写回数据库;若更新数据时,和数据库内数据的版本号不一致,就不允许更新,需要读出新版本号的数据继续操作

    乐观锁适用于多读的应用类型,这样可以提高吞吐量。Redis就是利用这种check-and-set机制实现事务的。

    四、乐观锁的使用

    在执行 multi 开启事务之前,先执行 watch key1 [key2],可以监视一个(或多个) key ,如果在事务执行之前这个(或这些) key 被其他命令所改动,那么事务将被打断

    在这里插入图片描述

    unwatch 取消 WATCH 命令对所有 key 的监视:如果在执行 WATCH 命令之后,EXEC 命令或DISCARD 命令先被执行了的话,那么就不需要再执行UNWATCH 了

    watch监视功能通过乐观锁实现

    两个终端都监视balance并开启事务
    在这里插入图片描述
    在这里插入图片描述
    终端1对balance加10
    在这里插入图片描述
    终端1对balance加20
    在这里插入图片描述
    终端1 exec执行事务成功
    在这里插入图片描述

    终端2 exec执行事务失败

    在这里插入图片描述
    分析: 乐观锁导致终端2事务执行失败;2个终端都得到balance这个数据,都对它监视,第一个终端先加10,然后就更新了版本号了,第二个终端执行加20,判断读取出来的balance的版本号和数据库里balance版本号,发现不一样了,就不能执行操作了

    五、Redis 事务三特性

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

    • 没有隔离级别的概念:开启事务后,没有exec提交之前命令只是存放在队列中,都不会实际被执行

    • 不保证原子性:事务中如果有一条命令执行失败,其后的命令仍然会被执行,没有回滚(这点和MySQL的原子性不一样)

  • 相关阅读:
    Qt实现Qchart的打印和打印预览的几种方法
    AI时代产品经理升级之道:ChatGPT让产品经理插上翅膀
    如何安装Jmeter监控服务器资源插件(JMeterPlugins + ServerAgent 方法一)?
    uni-app:实现图片周围的图片按照圆进行展示
    Node.js 实战 第2章 Node 编程基础 2.1 Node 功能的组织及重用
    半个月时间把MySQL重新巩固了一遍,梳理了一篇几万字 “超硬核” 文章!
    oracle数据库 表中有数据,通过plsql 工具 连接 查询全表,却查不到数据
    试试这些方法,误删文件怎么恢复?
    力扣(LeetCode)319. 灯泡开关(2022.11.16)
    可视化Docker管理工具-DockerUI
  • 原文地址:https://blog.csdn.net/qq_42500831/article/details/125591661
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | Kerberos协议及其部分攻击手法
    0day的产生 | 不懂代码的"代码审计"
    安装scrcpy-client模块av模块异常,环境问题解决方案
    leetcode hot100【LeetCode 279. 完全平方数】java实现
    OpenWrt下安装Mosquitto
    AnatoMask论文汇总
    【AI日记】24.11.01 LangChain、openai api和github copilot
  • 热门文章
  • 十款代码表白小特效 一个比一个浪漫 赶紧收藏起来吧!!!
    奉劝各位学弟学妹们,该打造你的技术影响力了!
    五年了,我在 CSDN 的两个一百万。
    Java俄罗斯方块,老程序员花了一个周末,连接中学年代!
    面试官都震惊,你这网络基础可以啊!
    你真的会用百度吗?我不信 — 那些不为人知的搜索引擎语法
    心情不好的时候,用 Python 画棵樱花树送给自己吧
    通宵一晚做出来的一款类似CS的第一人称射击游戏Demo!原来做游戏也不是很难,连憨憨学妹都学会了!
    13 万字 C 语言从入门到精通保姆级教程2021 年版
    10行代码集2000张美女图,Python爬虫120例,再上征途
Copyright © 2022 侵权请联系2656653265@qq.com    京ICP备2022015340号-1
正则表达式工具 cron表达式工具 密码生成工具

京公网安备 11010502049817号