Redis-5 分布式锁

server/2024/10/22 8:12:10/

一.为什么要使用分布式锁?

传统的互斥锁synchronized只能作用于同一台虚拟机上的线程,在使用服务器集群部署的情况下,互斥锁就会失效,因此要采用分布式锁来处理不同服务器上的线程访问同一资源的情况。

二.redis分布式锁是如何实现的?

1.通常采用redis的一个框架redisson去使用分布式

2.redisson的分布式锁底层是基于setnx和lua脚本实现的

(1)setnx:set if not exists,由于redis是单线程的,因此用了该命令后只能有一个客户端可以对该key设置值;在key没有过期或被删除的情况下,其他客户端是不能修改这个key的。

(2)lua脚本:加锁、设置过期时间等操作都是通过lua脚本完成的,lua脚本会调用redis的命令去完成操作,通过lua脚本可以保证多条命令执行的原子性。

三.redisson实现的分布式锁如何合理控制锁的有效时长?

1.redisson的分布式锁引入了WatchDog(看门狗)机制:当一个线程获得分布式锁之后,系统每隔一段时间就会去检查该线程是否还持有锁(默认是每10秒检查一次),如果线程还持有锁,则为其延长锁的持有时间,等到业务完成后线程自己释放锁即可

2.如果在线程持有分布式锁期间redis宕机,此时WatchDog机制也会随着redis宕机而崩掉,则线程会在本次持有时间结束后释放锁,这样就避免了死锁的发生

3.在线程1持有锁期间,若有线程2也要申请互斥锁,则线程2会:不断尝试获取锁,直到线程1释放锁线程2获取锁;或者超过了最大等待时间,放弃获取锁。

四.redisson实现的分布式锁可以重入吗?

1.重入:是指任意线程获取锁之后能够再次获取锁而不会被阻塞。

2.答:

(1)redisson实现的分布式锁可以重入,这个功能可以防止死锁的发生

(2)这个重入就是在内部判断该线程是否持有锁,如果持有锁则对该线程的重入次数进行计数,当线程释放锁则计数减1

(3)对重入进行计数,存储数据时是通过hash结构存储的,大key根据业务定制,小key是当前线程的唯一标识,value是当前线程重入的次数

五.redisson实现的分布式锁能解决主从一致性的问题吗?

1.redisson实现的分布式锁不能解决主从一致性的问题,假设线程1加锁成功,master节点还未将这一数据同步到slave节点就宕机了,那么线程1的加标识将丢失

2.主从一致性问题也可以通过使用redisson提供的红锁来解决,红锁要求每次加锁至少要在一半以上的redis实例上创建锁,但使用红锁会造成性能低下的问题

3.如果业务中必须要保证数据的强一致性,建议采用zookeeper实现的分布式


http://www.ppmy.cn/server/38916.html

相关文章

【Qt】深入理解QWidget常用控件: enable属性、geometry属性和window frame属性

文章目录 前言:1. 什么是控件2. Qt中QWidget控件的常用属性及元编程QWidget 核心属性enable属性:geometry 属性 :window frame 窗口框架 总结: 前言: 图形化界面的开发常常需要使用各种控件,而Qt作为一个强大的跨平台GUI应用程序…

Java实现NFS文件上传、下载和读取功能的工具类

Java实现NFS文件上传、下载和读取功能的工具类 引言:代码示例一、准备工作二、工具类设计与核心方法三、异常处理与性能优化四、总结 引言: NFS(Network File System)广泛应用于分布式环境的情况下,这里介绍使用Java工…

基于Springboot的校园悬赏任务平台(有报告)。Javaee项目,springboot项目。

演示视频: 基于Springboot的校园悬赏任务平台(有报告)。Javaee项目,springboot项目。 项目介绍: 采用M(model)V(view)C(controller)三层体系结构…

INNODB和MyISAM有什么区别

InnoDB和MyISAM是MySQL数据库中两种常见的存储引擎,它们之间存在一些重要的区别。 事务支持:InnoDB支持ACID(原子性、一致性、隔离性和持久性)事务,这保证了数据的完整性和一致性。相比之下,MyISAM不支持事…

2024OD机试卷-数组连续和 (java\python\c++)

题目:数组连续和 题目描述 给定一个含有N个正整数的数组, 求出有多少个连续区间(包括单个正整数), 它们的和大于等于x。 输入描述 第一行两个整数N x(0 < N <= 100000, 0 <= x <= 10000000) 第二行有N个正整数(每个正整数小于等于100)。 输出描述 输出一…

基于自己数据微调LLama3并本地化部署

首发网站https://tianfeng.space 准备数据 这是一条数据&#xff0c;格式如下&#xff1a; {"instruction": "胡女士出现了黄疸、恶心、呕吐等症状&#xff0c;可能患了什么疾病&#xff1f;", "input": "", "output": &…

算法提高之迷宫问题

算法提高之迷宫问题 核心思想&#xff1a;最短路问题 从(n-1,n-1)开始bfs 往前走一个就存入pre数组 之后再遍历pre数组输出 #include <iostream>#include <cstring>#include <algorithm>using namespace std;const int N 1010,M N*N;#define x first#def…

信通院智能体标准发布,实在智能牵头编写

4月28日&#xff0c;由人工智能关键技术和应用评测工业和信息化部重点实验室、中国信息通信研究院&#xff08;以下简称&#xff1a;中国信通院&#xff09;人工智能研究所共同主办的“人工智能”高质量发展研讨会顺利召开&#xff0c;会上中国信通院正式发布全国首个Agent&…