【redis笔记】分布式锁

什么需要分布式锁

分布式场景下,原单机的多进程多线程并发控制策略会失效,典型的像海量key分布在redis集群中,那么对这些key的并发修改操作就不像单机那样容易保证有序(单机的锁只对单机有效),这时就需要使用分布式锁来实现并发控制。

通常可以有以下几种分布式锁实现方式:

  • 基于数据库实现
  • 基于redis实现
  • 基于Zookeeper实现

我们可以使用redis来实现分布式的锁来控制分布式应用的并发策略。利用的是setnx在已经设置值后,会返回0的特性。

怎么避免分布式锁一直被占用

通常我们需要避免某个任务一直占用锁导致其他任务无法顺利执行的场景,我们可以通过设置锁的过期时间来让锁自动失效。

为了上锁后如果出现redis服务异常,导致过期时间设置失败,一般上锁时要同步进行过期时间设置,如下上锁并设置lock过期时间10秒

c 复制代码
set lock 1 nx ex 10

怎么避免锁被误删除

考虑以下场景,A加了一把锁,过期时间3秒,在手动释放锁之前过期了,B这时加锁进行了自己的操作,这时A执行到了解锁,就会导致A把B加的锁删除了

一种有效的解决方案是每个具体的服务生成一个uuid,当我们加锁时,我们把值设置成自己的uuid,释放锁的时候去获取此时锁的uuid值,如果一样就释放,不一样就不释放。

但由于比较和删除的操作不是原子的,如果我们比较是否相等之后,还没删除,就过期了,如果刚好被另外一个服务抢占了,那么还是会误删除。为了解决这个问题,我们也可以使用LUA脚本来保证执行的原子性

相关推荐
小小工匠16 小时前
Redis - 事务机制:能实现 ACID 属性吗
数据结构·redis·性能优化·并发·持久化
闪闪发亮的小星星17 小时前
高斯光以及高斯光公式解释
笔记
cqbzcsq18 小时前
CellFlow虚拟细胞论文阅读
论文阅读·人工智能·笔记·学习·生物信息
阿米亚波19 小时前
【Windows】QEMU 启动 openEuler aarch64/arm64 架构系统 + 离线软件源
linux·windows·经验分享·笔记·架构·arm
自传.19 小时前
尚硅谷 Vibe Coding|第三章(1) Claude Code深度使用与进阶技巧 学习笔记
笔记·学习·尚硅谷·vibecoding
.千余20 小时前
【C++】模板进阶全解:非类型参数|全特化|偏特化|分离编译完全指南
开发语言·c++·笔记·学习·其他
自传.20 小时前
尚硅谷 Vibe Coding|第二章 AI编程工具生态 学习笔记
笔记·学习·ai编程·尚硅谷·vibe coding
taocarts_bidfans20 小时前
反向海淘跨境缓存架构优化:taocarts Redis分层缓存实战技术
redis·缓存·架构·反向海淘·taocarts
秋波。未央21 小时前
Java Agent 开发 · Day 1 学习笔记(含作业完整标准答案)
java·笔记·学习
中屹指纹浏览器1 天前
2026指纹浏览器字体指纹、字体渲染偏差检测与全维度虚拟字体池搭建方案
经验分享·笔记