分布式-锁

embedded/2024/11/15 8:17:17/

一、锁的业务场景

1、为什么要加锁?

在多线程环境下,针对一些共享资源往往会出现线程安全问题,需要加锁校准程序执行过程。

2、单机锁的类型

synchronized 关键字。

Lock 接口的锁。

atomic 包的封装类。

3、分布式场景中的锁

分布式系统中,如果只是在一台服务器内对某个资源加锁,但是无法对其他服务器生效,数据安全问题还是存在。

4、分布式锁的类型

MySQL ------  加锁语句

Redis    ------  Lua脚本写分布式

ZooKeeper ----- 分布式

二、MySQL实现分布式

// 使用MySQL的排他锁

select * from table where id = ABC for update;

优点是可以很轻松地编写代码实现分布式锁。

缺点是在分布式场景下容易造成长时间的锁等待,导致系统性能下降严重。并且需要手动控制事务,代码编写繁琐,并且会进一步延长锁等待的时间。

三、Redis实现分布式

1、手动实现分布式

加锁:set key threadId ex time nx

解锁:LUA脚本 -> 先get key,对比threadId,再del key。

2、Redisson

使用Redisson可以快速简单地使用一个分布式锁。

3、RedLock

红锁是redis推出的一个应对极端情况的分布式锁,要求最少有五台redis节点,并且在锁过期时间内最少有三台返回成功,才能获取锁。

优点:更加健壮、即使在加锁过程中出现了一台redis掉线了,也不会影响主业务流程。

缺点:配置繁琐,无法避免分布式环境的NPC问题。

N:网络延迟。

P:进程暂停。如果恰好某一台redis服务器出现了GC处理,就会导致进程暂停。

C:时钟漂移。无法确保每一台redis服务器的时间一致。

四、Zookeeper中实现分布式

1、依靠ZK节点类型中的临时序号节点实现。

临时节点有过期时间,避免死锁。

2、ZooKeeper实现分布式锁的原理。

3、实战案例分析。


http://www.ppmy.cn/embedded/136808.html

相关文章

Java反射原理及其性能优化

目录 JVM是如何实现反射的反射的性能开销体现在哪里如何优化反射性能开销 1. JVM是如何实现反射的? 反射是Java语言中的一种强大功能,它允许程序在运行时动态地获取类的信息以及操作对象。下面是一个简单的示例,演示了如何使用反射调用方法&#xff…

非关系型数据库(1)---MongoDB

目录 1.MongoDB 1.MongoDB的特点 2.MongoDB的应用场景 3.MongoDB与MySQL的比较 2.数据库操作 1. 创建数据库 2. 切换数据库 3. 查看所有数据库 4. 查看当前数据库 5. 删除数据库 6. 查看数据库统计信息 7. 备份数据库 8. 恢复数据库 9. 创建用户和授权 10. 删除用…

CSS教程(四)- 字体

1、尺寸单位 px 像素单位% 百分比,参照父元素对应属性的值进行计算em 字体尺寸单位,参照父元素的字体大小计算,1em16pxrem字体尺寸单位,参照根元素的字体大小计算,1rem16px 2、字体属性 介绍 CSS Fonts (字体)属性用于定义字体…

NLP论文速读|LongReward:基于AI反馈来提升长上下文大语言模型

论文速读|LongReward: Improving Long-context Large Language Models with AI Feedback 论文信息: 简介: 该论文试图解决的问题是如何提高长文本上下文大型语言模型(LLMs)在监督式微调(SFT)中的性能&#…

JVM知识点大全(未完...)

JVM运行时数据区域 堆 堆是Java虚拟机中用于存储对象的主要区域,包括字符串常量池。绝大多数对象都是在堆中创建的(少部分对象可能会在栈上分配)。为了更好地进行垃圾回收,堆被划分为年轻代和老年代两部分。年轻代又被进一步分为E…

【IC每日一题:IC验证面试常问-3】

【IC每日一题:IC验证面试常问-3】 1.1 SV约束如何使用以及有哪几种方式?”:“和":/"的区别?,rand和randc的区别?如何关闭约束?1.2 代码覆盖率、功能覆盖率、SVA覆盖率都是衡量什么的;…

创新体验触手可及 紫光展锐携手影目科技推出AI眼镜开放平台

近日,紫光展锐携手影目科技共同发布了搭载展锐W517芯片的影目X系列AI眼镜开放平台。这一产品的推出标志着双方在智能穿戴领域的深度协作,将紫光展锐的领先芯片技术与影目的产品创新相融合,合力打造全球智能眼镜市场的标杆产品。这一战略布局不…

动态避障-图扑自动寻路 3D 可视化

自动寻路是机器人导航的核心技术,其原理主要涉及机器人与环境之间的复杂信息交互与处理。在自动寻路过程中,机器人依靠先进的传感器系统,如高清摄像头、精密激光雷达和灵敏超声波装置,全方位感知周围环境。这些传感器能够实时捕捉…