码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • Redis-分布式锁


    分布式锁相关内容

    • 超卖问题切入
    • 可以使用互斥锁给先获取到锁的线程加锁吗?
    • 使用redis分布式锁解决超卖问题
      • setnx命令实现分布式锁
        • 为什么需要设置过期时间?
        • Redis实现分布式锁如何合理控制锁的有效时长
      • redisson实现分布式锁

    在这里插入图片描述

    超卖问题切入

    我们先来看一个项目中的真实的场景: 抢卷的场景
    在这里插入图片描述
    咋一看流程好像特别正常,但是但是这是一个抢卷的过程,疯狂程度可想而知,并且线程又是交替进行的,可能在线程1刚查询到库存时,线程2同时也拿到了库存,此时线程1和线程2拿到的库存量是相同的,比如都是1,但是线程1先进行了-1操作,而线程2此时拿到的值仍然是1,他并不知道有别的线程已经修改了值为0,那么当线程2进行-1操作时,就会出现超卖的问题,具体的流程图如下:
    在这里插入图片描述

    可以使用互斥锁给先获取到锁的线程加锁吗?

    如果你的项目是一个单体的项目,只启动了一个服务,那么是完全没问题的,具体的流程以及代码可以参考下面:
    在这里插入图片描述
    在这里插入图片描述
    如果我们把项目代码通过nginx反向代理部署到多个服务器上,那么这种方案就不行了,单个JVM下能保证线程和线程之间的互斥,但是多个服务器多个JVM之间是无法互斥的

    使用redis分布式锁解决超卖问题

    在上面我们讲到多个服务之间我们无法让不同JVM之间的互斥锁产生效果,那么我们可以想一下,如果我们通过一个媒介,在多个服务内只要有线程加到锁了,那么就记录一下,如果有别的线程再来加锁,就能产生互斥的效果了,这个媒介就是分布式锁,具体的流程可以参考下图
    在这里插入图片描述

    setnx命令实现分布式锁

    /**
    获取锁
    **/
    SET lock value NX EX 10
    /**
    释放锁
    **/
    DEL key
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8

    为什么需要设置过期时间?

    如果不设置过期时间,通过setnx命令获取到锁之后,在还没释放锁之前,如果业务超时或者服务宕机,那么就会一直占用着这把锁,会出现死锁的问题,但是如果设置了过期时间的话,当这把锁过期之后就会自动的将锁给释放。

    Redis实现分布式锁如何合理控制锁的有效时长

    过期时间太长了,如果业务代码早早的就执行完了,影响整体的效率
    过期时间太短了,如果业务代码还没执行完就过期了也不行
    如果我们自己凭感觉去填一个过期时间,其实是非常不靠谱的一件事情,那如果我们再开一个线程来监控这把锁呢?当锁过期之后给锁续期,这个是不是听着就比较靠谱了,其实市面上早就已经有了这种技术实现了,下面我们就来讲一下redisson

    redisson实现分布式锁

    我们来看一下具体的流程:
    在这里插入图片描述
    通过看门狗机制能够实现续期,默认是每隔10秒的时间做一次续期,而抢不到锁的线程会进行尝试等待,进行while循环不断尝试获取锁
    在这里插入图片描述

  • 相关阅读:
    自动化发布npm包小记
    Spring6(三):面向切面AOP
    APP 兼容性专项测试
    C++11右值引用的价值体现
    《痞子衡嵌入式半月刊》 第 97 期
    读书笔记:软件工程(3) - 软件生存周期
    java计算机毕业设计校园互助系统源码+系统+mysql数据库+lw文档+部署
    117. 本地开发好的 SAP UI5 应用部署到 ABAP 服务器时,中文字符变成乱码的原因分析和解决方案
    泰迪智能科技大模型数据智能实验室
    压力测试详解,如何进行Jmeter压力测试
  • 原文地址:https://blog.csdn.net/m0_56642224/article/details/133624584
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | 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号