分布式-锁

一、锁的业务场景

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、实战案例分析。

相关推荐
山岚的运维笔记25 分钟前
SQL Server笔记 -- 第73章:排序/对行进行排序
数据库·笔记·后端·sql·microsoft·sqlserver
苍何1 小时前
豆包还能这么玩?附 13 大隐藏玩法,效率起飞(建议收藏)
后端
苍何1 小时前
Kimi 版 OpenClaw 来了,5000+ Skills 随便用,确实给力!
后端
百锦再2 小时前
Jenkins 全面精通指南:从入门到脚本大师
运维·后端·python·servlet·django·flask·jenkins
forestsea2 小时前
优雅终结启动顺序噩梦:ObjectProvider —— Spring 4.3 开始引入
java·后端·spring
小楼v2 小时前
⭐解锁RAG与Spring AI的实战应用(万字详细教学与完整步骤流程实践)
java·后端·rag·spring ai·ai大模型应用
毕设源码-小云学姐2 小时前
计算机毕业设计springboot医疗档案管理系统 基于 SpringBoot 的电子医疗档案管理系统的设计与实现 SpringBoot 框架下的医疗档案信息化管理系统开发
spring boot·后端·课程设计
那我掉的头发算什么2 小时前
【SpringBoot】一篇文章讲清楚拦截器所有知识
java·spring boot·后端·spring
Loo国昌2 小时前
【AI应用开发实战】 03_LangGraph运行时与状态图编排:从直接执行到图编排的演进之路
人工智能·后端·python·自然语言处理·prompt
没有bug.的程序员4 小时前
Gradle 构建优化深度探秘:从 Java 核心到底层 Android 物理性能压榨实战指南
android·java·开发语言·分布式·缓存·gradle