Redis-典型应用-分布式锁

目录

1.什么是分布式锁?

2.分布式锁的实现

3.引入过期时间

4.引入校验ID

5.引入lua脚本:

6.引入看门狗(watch dog)

7.引入redislock算法:


1.什么是分布式锁?

 在 分布式系统中,会出现多个节点同时访问同一个公共资源, 此时就需要通过锁来作互斥控制,避免出现类似于多线程中的"线程安全"问题.

2.分布式锁的实现

分布式锁实现的本质是 通过一个键值对来标识锁的状态.在redis上写入一个key-val.

mysql的事务也能起到避免线程安全问题实现查询+修改操作,但是在实际使用的过程中,不一定是mysql, 也可能是其他存储介质.

加锁: 不能存在时就设置,存在就设置失败,可以使用redis中的setnx 命令可以实现这个场景.

解锁: 使用del命令实现.

3.引入过期时间

当对一个数据加锁后,若还未执行解锁的逻辑,程序突然崩溃了,就会导致加了锁无法正常释放.

可以通过设置一个过期时间机制,达到过期时间,自动删除.达到锁被自动释放的效果.

通过 set ex nx命令来实现.

setnx ,expire这两个命令也能实现设置过期时间的功能,但不能通过这个命令来实现.

因为redis的命令的原子性,随能保证不允许被别的命令插队,但不能保证一个事务中的所有命令是全部执行成功,若中间有命令执行失败,就无法保证锁的正确设置了.

通过set nx ex一条命令,一定能保证要么执行成功,要么全部执行失败.

4.引入校验ID

当一个服务器对redis设置了一个key-val.,进行了加锁;

而另一个服务器对redis中的该值进行了误删除,这就出现了错误的逻辑.

为了解决这个问题,可以引入校验id,让key对应的val中存储加锁的服务器编号,当进行解锁时, 只有该编号的服务器对其解锁才能解锁成功,其他服务器对其解锁,都会解锁失败.

这样就避免了误删除操作.

5.引入lua脚本:

在一个服务器内部,可能有多个线程.

当两个线程前后对同一个redis进行解锁时,由于解锁的需要先判断是否是该服务器上锁的,然后进行解锁,不是原子性的,可能引发两次解锁.

在执行解锁操作时,服务器一的线程1先执行get命令,判断是否是该线程加的锁,在执行del命令之前, 然后又一个线程2,执行get,此时还未解锁,线程2的get是成功的,

然后线程1执行了del操作,锁释放成功,

线程2再执行del操作,就会执行失败.这就是锁被重复.

但若在3,4步之间,又有一个服务器2的线程执行set nx ex上操作,此时线程b的del命令由于已经通过了判定, 就会将服务器2刚上的锁给释放了,就会出现错误.这是释放锁的命令不是原子性造成的.

可以通过lua脚本来解决解锁时命令不是原子的的问题,

lua脚本是一个轻量级的编程语言,内嵌到redis中,使用lua编写一些程序,然后将这个脚本上传到redis服务器上,就可以让客户来控制redis执行上述lua脚本命令了.

redis执行lua脚本的过程是原子的,相当于一条命令在执行.

6.引入看门狗(watch dog)

设置过期时间,当过期时间到了,还需要继续使用呢,又要怎样将过期时间进行续约呢?

使用"动态续约"来实现.

初始情况下,设置一个过期时间,当过期时间马上到了,还未有线程来释放锁,就会自动续约,再加上一段过期时间,时间又快到了,任务还没执行完,就再续上一段时间.这样既能保证当任务还没执行完时,不会自动解锁,又能保证当程序中途出现崩溃,锁还未释放时,就无法自动续约了,当到了过期时间,就自动解锁了.

7.引入redislock算法:

这里有个问题,当用来加锁的redis出现故障了,突然挂了,那所有的加锁信息就没了.

这就要用之前的知识了,使用主从复制,引入多个从节点,进行主从信息同步,即使主节点挂了,从节点也保存了加锁的信息.

但这里又有一个问题,主从节点数据同步是存在一个延迟性的,万一主节点刚收到一个加锁信息,还没来得及同步给从节点,主节点就挂了,那样就出现数据丢失了.

为了解决这个问题,可以使用redislock 算法:使用集群的方法,引入多个redis主节点,每个主节点都创建多个从节点,当要写入数据时,对每个主节点都执行相同的写入命令,起到一个备份的作用.

 当执行成功的节点个数超过总主节点的一半时,才视为执行成功,即使有某个主节点挂了,还有别的主节点已经存储了数据.这样就能保证加锁,解锁的正确性了.

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如若转载,请注明出处:http://www.pswp.cn/pingmian/89452.shtml
繁体地址,请注明出处:http://hk.pswp.cn/pingmian/89452.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Dinky (Mac) 本地开发环境搭建指南

目录 一、前置条件 二、代码准备 三、前端环境搭建 1. 安装Node环境 2. 安装PNPM 3. 构建前端 四、后端环境搭建 1. 本地编译依赖 2. 添加必要依赖 3. 启动后端服务 五、访问系统 附录:官方参考 一、前置条件 确保已安装以下软件: 软件要求…

Java Set 集合详解:从基础语法到实战应用,彻底掌握去重与唯一性集合

作为一名 Java 开发工程师,你一定在实际开发中遇到过需要去重、唯一性校验、快速查找等场景。这时候,Set 集合 就成为你不可或缺的工具。本文将带你全面掌握:Set 接口的定义与核心方法常见实现类(如 HashSet、TreeSet、LinkedHash…

在分布式系统中,如何保证缓存与数据库的数据一致性?

口诀: 读多写少用旁路,先更库再删缓存; 强一致选写透,缓存代理更库走; 性能优先用写回,异步批量有风险; 高并发加双删,延迟兜底防旧残; 强一致用锁串,并发虽低…

【洛谷P1417】烹调方案 题解

题目大意 一共有 nnn 件食材,每件食材有三个属性,aia_iai​,bib_ibi​ 和 cic_ici​,如果在 ttt 时刻完成第 iii 样食材则得到 ai−tbia_i-t\times b_iai​−tbi​ 的美味指数,用第 iii 件食材做饭要花去 cic_ici​ 的…

vue svg实现一个环形进度条组件

svg实现一个环形进度条设计初衷:本来想直接使用element的进度条组件的,但是好多属性都没有办法控制。 UI设计的图如下,需要控制未完成和已完成的颜色,端点的形状改为普通的butt 所以使用svg实现了一个环形进度条组件element组件设…

02 51单片机之LED闪烁

文章目录1、单片机1-1、简介1-2、应用场景2、51单片机2-1、背景2-2、主要品牌及其产品2-3、基本组成2-4、命名规则3、单片机内部结构3-1、单片机内部结构图3-2、单片机内部结构3-3、单片机内部管脚图3-4、单片机最小系统3-5、开发板介绍4、点亮LED4-1、新建工程4-1-1、创建工程…

Typecho博客集成算术验证码防御垃圾评论实战指南

文章目录 Typecho实现算术验证码防御机器人垃圾评论的完整方案 背景与问题分析 技术方案设计 系统架构 技术选型 核心实现步骤 1. 创建验证码生成函数 2. 修改评论表单模板 3. 添加AJAX刷新功能 4. 创建验证码刷新接口 5. 添加评论提交验证 安全增强措施 1. 防止暴力破解 2. 增…

clonezilla 导出自动化恢复iso

clonezilla 下载及U盘工具下载 clonezilla rufus U盘写入工具ventoy U盘工具downloaddownloaddownload clonezilla 备份,连贯上一篇文章参考 Choose Clonezilla live (VGA 800x600) Wait for it to complete Language selection Keyboard Settings Select Mode …

深度学习模型开发部署全流程:以YOLOv11目标检测任务为例

深度学习模型开发部署全流程:以YOLOv11目标检测任务为例 深度学习模型从开发到部署的完整流程包含需求分析、数据准备、模型训练、模型优化、模型测试和部署运行六大核心环节。YOLOv11作为新一代目标检测模型,不仅延续了YOLO系列的高效实时性能&#xff…

单片机(STM32-串口通信)

一、串口通信基础概念串口通信(Serial Communication)是一种在计算机和外部设备之间进行数据传输的通信方式。它通过串行方式逐位传输数据,是最基本和常用的通信接口之一。主要特点1. 串行传输(1)数据按位顺序传输,一次只能传输一…

Redis学习其三(订阅发布,主从复制,哨兵模式)

文章目录9.Redis订阅与发布9.1发布订阅命令9.2示例10.Redis主从复制10.1概念10.2环境配置10.3集群搭建(一主二从配置)10.4使用规则&原理11.哨兵模式11.1基本概念11.2工作原理11.3使用案例12.缓存穿透,雪崩(待拓展)12.1缓存穿透…

跨平台 App 如何无痛迁移到鸿蒙系统?全流程实战+Demo 教程

摘要 目前,随着 HarmonyOS(鸿蒙系统)的快速发展,越来越多开发者和企业希望将已有的 Android、Flutter、React Native 等跨平台应用迁移到鸿蒙生态中。鸿蒙不仅具备分布式能力、原生性能和统一的开发范式,还提供了丰富的…

智慧后厨检测算法构建智能厨房防护网

智慧后厨检测:构建安全洁净厨房的智能解决方案背景:传统后厨管理的痛点与智慧化需求餐饮行业后厨管理长期面临操作规范难落实、安全隐患难察觉、卫生状况难追溯等痛点。传统人工巡检效率低、覆盖面有限,难以实现24小时无死角监管。例如&#…

LatentSync: 一键自动生成对嘴型的视频

LatentSync是什么 字节跳动与北京交通大学联合推出了全新的唇形同步框架 LatentSync,它基于音频驱动的潜在扩散模型,跳过了传统的3D建模或2D特征点提取,直接生成自然逼真的说话视频。 LatentSync借助Stable Diffusion强大的图像生成能力&am…

在断网情况下,网线直接连接 Windows 笔记本和 Ubuntu 服务器进行数据传输

在断网情况下,通过网线直接连接 Windows 笔记本 和 Ubuntu 服务器上的容器 进行数据传输,可以按照以下步骤操作:1. 物理连接 使用网线直连:用一根 普通网线(直通线) 连接 Windows 笔记本和 Ubuntu 服务器的…

机器学习17-Mamba

深度学习之 Mamba 学习笔记 一、Mamba 的背景与意义 在深度学习领域,序列建模是一项核心任务,像自然语言处理、语音识别和视频分析等领域,都要求模型能有效捕捉长序列里的依赖关系。之前,Transformer 凭借强大的注意力机制成为序列…

Java实现word、pdf转html保留格式

一、word转html 依赖&#xff1a; <properties><poi.version>5.2.3</poi.version><xhtml.version>2.0.4</xhtml.version> </properties><!--word转html--> <dependency><groupId>org.apache.poi</groupId><a…

基于51单片机和16X16点阵屏、矩阵按键的小游戏《俄罗斯方块》

目录系列文章目录前言一、效果展示二、原理分析三、各模块代码1、16X16点阵屏&#xff08;MAX7219驱动&#xff09;2、矩阵按键3、定时器0四、主函数总结系列文章目录 前言 《俄罗斯方块》&#xff0c;一款经典的、怀旧的小游戏&#xff0c;单片机入门必写程序。 有两个版本&…

Stable Diffusion Windows本地部署超详细教程(手动+自动+整合包三种方式)

Stable Diffusion Windows 本地部署超详细教程 (手动 自动 整合包三种方式) 一、引言 我们可以通过官方网站 Stability AI&#xff0c;以及 Dream Studio、Replicate、Playground AI 、Baseten 等网站在线体验 Stable Diffusion 的巨大威力。相比于集成在网络平台的 SD 或者…

sqli-labs靶场通关笔记:第29-31关 HTTP参数污染

第29关 HTTP参数污染本关设置了web应用防火墙&#xff08;WAF&#xff09;&#xff0c;利用白名单保护机制来检测和拦截恶意请求。看本关源代码。<?php //including the Mysql connect parameters. include("../sql-connections/sql-connect.php"); //disable er…