当前位置: 首页 > news >正文

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

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

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

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

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

redisson实现分布式锁

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

http://www.lryc.cn/news/183957.html

相关文章:

  • 什么时候使用继承,好莱坞原则(设计模式与开发实践 P11+)
  • 蓝桥等考Python组别十四级001
  • TI单芯片毫米波雷达代码走读(二十七)—— 角度维(3D)处理之通道间幅相一致性补偿
  • 数据结构 2.2 单循环链表
  • 矩阵距离——多源BFS
  • 关于在 Notion 中使用 Markdown 语法
  • sigmoid和softmax函数有什么区别
  • 第五章:最新版零基础学习 PYTHON 教程—Python 字符串操作指南(第七节 - Python 中使用 % 进行字符串格式化)
  • 【网络安全 --- 工具安装】VMware 16.0 详细安装过程(提供资源)
  • Eclipse MAT解析headp dump,total size小于file size
  • 【数据挖掘】2022年 Quiz 1-3 整理 带答案
  • AcWing 288. 休息时间,《算法竞赛进阶指南》,环形与后效性处理
  • 一文掌握Linux系统信息查看命令(CPU、内存、进程、网口、磁盘、硬件)
  • UE5.1编辑器拓展【三、脚本化资产行为,删除无引用资产】
  • 防抖和节流的实现
  • alsa pcm接口之阻塞和非阻塞打开和异步通知模式
  • Python Random模块详解
  • Vue3 模糊搜索筛选
  • 【MVC】C# MVC基础知识点、原理以及容器和管道
  • 【kubernetes】基于prometheus的监控
  • Gmail 将停止支持基本 HTML 视图
  • 电影大师杂记
  • 聊聊分布式架构——RPC通信原理
  • Android:实现手机前后摄像头预览同开
  • 2.2.4 yocto poky openembedded bitbake关系
  • 开源后台管理系统 (go-vue-admin)
  • 想升级macOS Big Sur,但是MacBook内存空间不够该怎么办?
  • 结构化面试 --- 介绍 + 人际关系
  • 李沐深度学习记录5:13.Dropout
  • 计算机竞赛 题目:基于大数据的用户画像分析系统 数据分析 开题