Redis (分布式锁)

本文涉及的产品
Redis 开源版,标准版 2GB
推荐场景:
搭建游戏排行榜
云数据库 Tair(兼容Redis),内存型 2GB
简介: Redis (分布式锁)

什么是分布式锁?

分布式系统下, 会涉及到多个 进程 同时访问同一个公共资源的情况, 此时就需要通过 来做互斥操作, 这个锁就被称为 分布式锁

分布式锁的本质: 使用 一个或一组服务器 来记录 加锁状态

以 Redis 做分布式锁为例:

  • 把 Redis 中存储的 一个键值对, 当作 .
  • 当其他进程使用公共资源前, 都需要尝试往Redis 中存储该键值对, 视为 加锁操作 , 如果该键值对已存在, 则加锁失败, 不能使用公共资源
  • 当占用公共资源的进程结束使用后, 由该进程把 Redis 中的 “锁” 删除掉, 视为 解锁操作

Redis 可用作分布式锁的原因 :

  1. 单线程模型, 同一时刻只能由一个进程的一个线程进行加锁和解锁操作
  2. 加锁 : setnx 不存在就设置, 存在就设置失败
  3. 解锁 : del

设置过期时间 (set ex nx)

error : 加锁后, 还未解锁, 该进程就挂了 (相当于锁资源不会再被释放了 …)

tips : 此处只能使用 set ex nx , 而不能使用多个命令 setnx + expire (两个命令如果有一个没有执行成功, 就会出现不符合预期的情况)

设置校验 Id

error : 服务器 A 加锁, 但是服务器 B 进行了误操作, 给解锁了 (Redis 中锁就是一个键值对, 理论上谁都能删除)

solve :

  1. 给每个服务器加唯一的身份标识
  2. 作为锁的键值对中, value 值存储加锁对象的 身份标识
  3. 每次解锁前进行校验是否是你给我加的锁
  4. 校验成功就解锁, 校验失败则解锁失败

事务 / lua 脚本

error : 解锁过程中的原子性问题


以上图为例, 原本一个进程中有两个线程尝试进行解锁, 因为 进程是同一个, 因此都可以进行解锁, 并且第二次解锁虽然不成功但是不会产生其他影响

如果在两次 del 之间有其他进程尝试加锁, 由于第一个进程已解锁, 所以加锁进行可以通过校验并成功加锁, 但是第二次解锁操作会让中间进程的加锁操作无效掉

Redis 事务保证在事务执行过程中, 不会有其他进程命令的 插队

Redis 服务器以原子的方式来执行 lua 脚本 (即使该脚本中存在多条命令)

因此可以解决上述问题


看门口 “watch dog”

error : 针对过期时间设置过长 (过期时间设定太长了,导致占用公共资源进程早就使用完毕, 但是公共资源还是没有被释放) 或者 锁提前失效 (业务提前结束)

solve : 引入看门狗思想, 用 业务服务器上的 一个线程对 “锁” 进行持续 续约

eg:

  • 锁的初始过期时间设置为 1s , 当还剩余 300ms 时, 重新设置过期时间为 1s …
  1. 当该进程使用公共资源完毕时, 看门口就不再给 锁 续时间, 锁就会很快被释放掉
  2. 当业务服务器挂了, 看门狗线程也就不存在了, 也就不会继续续约, 公共资源很快就会被释放

redlock 算法 – 引入冗余

error : 当一个进程给 master 加锁成功, 但是 master 还未同步给它的 slave 时, master 就挂了, 经过哨兵的重建主从结构后, 该结构会认为, 我此时处于 无锁 状态

solve : 每次加锁不是针对一个 Redis 对象, 而是针对一组 redis master 对象加锁, 当加锁成功个数大于总数的一半, 我们就认为本次加锁成功, 解锁时对所有 master 进行解锁.

相关实践学习
基于Redis实现在线游戏积分排行榜
本场景将介绍如何基于Redis数据库实现在线游戏中的游戏玩家积分排行榜功能。
云数据库 Redis 版使用教程
云数据库Redis版是兼容Redis协议标准的、提供持久化的内存数据库服务,基于高可靠双机热备架构及可无缝扩展的集群架构,满足高读写性能场景及容量需弹性变配的业务需求。 产品详情:https://www.aliyun.com/product/kvstore     ------------------------------------------------------------------------- 阿里云数据库体验:数据库上云实战 开发者云会免费提供一台带自建MySQL的源数据库 ECS 实例和一台目标数据库 RDS实例。跟着指引,您可以一步步实现将ECS自建数据库迁移到目标数据库RDS。 点击下方链接,领取免费ECS&RDS资源,30分钟完成数据库上云实战!https://developer.aliyun.com/adc/scenario/51eefbd1894e42f6bb9acacadd3f9121?spm=a2c6h.13788135.J_3257954370.9.4ba85f24utseFl
目录
相关文章
|
2月前
|
NoSQL Redis
基于Redis的高可用分布式锁——RedLock
这篇文章介绍了基于Redis的高可用分布式锁RedLock的概念、工作流程、获取和释放锁的方法,以及RedLock相比单机锁在高可用性上的优势,同时指出了其在某些特殊场景下的不足,并提到了ZooKeeper作为另一种实现分布式锁的方案。
73 2
基于Redis的高可用分布式锁——RedLock
|
2月前
|
缓存 NoSQL Java
SpringBoot整合Redis、以及缓存穿透、缓存雪崩、缓存击穿的理解分布式情况下如何添加分布式锁 【续篇】
这篇文章是关于如何在SpringBoot应用中整合Redis并处理分布式场景下的缓存问题,包括缓存穿透、缓存雪崩和缓存击穿。文章详细讨论了在分布式情况下如何添加分布式锁来解决缓存击穿问题,提供了加锁和解锁的实现过程,并展示了使用JMeter进行压力测试来验证锁机制有效性的方法。
SpringBoot整合Redis、以及缓存穿透、缓存雪崩、缓存击穿的理解分布式情况下如何添加分布式锁 【续篇】
|
20天前
|
存储 NoSQL Redis
SpringCloud基础7——Redis分布式缓存,RDB,AOF持久化+主从+哨兵+分片集群
Redis持久化、RDB和AOF方案、Redis主从集群、哨兵、分片集群、散列插槽、自动手动故障转移
SpringCloud基础7——Redis分布式缓存,RDB,AOF持久化+主从+哨兵+分片集群
|
2月前
|
缓存 NoSQL Java
SpringBoot整合Redis、以及缓存穿透、缓存雪崩、缓存击穿的理解、如何添加锁解决缓存击穿问题?分布式情况下如何添加分布式锁
这篇文章介绍了如何在SpringBoot项目中整合Redis,并探讨了缓存穿透、缓存雪崩和缓存击穿的问题以及解决方法。文章还提供了解决缓存击穿问题的加锁示例代码,包括存在问题和问题解决后的版本,并指出了本地锁在分布式情况下的局限性,引出了分布式锁的概念。
SpringBoot整合Redis、以及缓存穿透、缓存雪崩、缓存击穿的理解、如何添加锁解决缓存击穿问题?分布式情况下如何添加分布式锁
|
3天前
|
NoSQL 安全 关系型数据库
20)用 Redis 实现分布式锁
20)用 Redis 实现分布式锁
13 0
|
2月前
|
NoSQL 安全 Java
nicelock--一个注解即可使用Redis分布式锁!
Nicelock的引入为分布式系统中的资源同步访问提供了一个简单高效和可靠的解决方案。通过注解的方式,简化了锁的实现和使用,使开发人员可以将更多精力专注于业务逻辑的实现,而不是锁的管理。此外,Nicelock在保持简单易用的同时,也提供了足够的灵活性和可靠性,满足了不同应用场景下对分布式锁的需求。
34 1
|
2月前
|
NoSQL Go Redis
用 Go + Redis 实现分布式锁
用 Go + Redis 实现分布式锁
|
3月前
|
存储 缓存 NoSQL
Redis常见面试题(二):redis分布式锁、redisson、主从一致性、Redlock红锁;Redis集群、主从复制,哨兵模式,分片集群;Redis为什么这么快,I/O多路复用模型
redis分布式锁、redisson、可重入、主从一致性、WatchDog、Redlock红锁、zookeeper;Redis集群、主从复制,全量同步、增量同步;哨兵,分片集群,Redis为什么这么快,I/O多路复用模型——用户空间和内核空间、阻塞IO、非阻塞IO、IO多路复用,Redis网络模型
Redis常见面试题(二):redis分布式锁、redisson、主从一致性、Redlock红锁;Redis集群、主从复制,哨兵模式,分片集群;Redis为什么这么快,I/O多路复用模型
|
3月前
|
NoSQL Java Redis
分布式锁实现原理问题之使用Redis的setNx命令来实现分布式锁问题如何解决
分布式锁实现原理问题之使用Redis的setNx命令来实现分布式锁问题如何解决
|
3月前
|
canal 缓存 NoSQL
Redis常见面试题(一):Redis使用场景,缓存、分布式锁;缓存穿透、缓存击穿、缓存雪崩;双写一致,Canal,Redis持久化,数据过期策略,数据淘汰策略
Redis使用场景,缓存、分布式锁;缓存穿透、缓存击穿、缓存雪崩;先删除缓存还是先修改数据库,双写一致,Canal,Redis持久化,数据过期策略,数据淘汰策略
Redis常见面试题(一):Redis使用场景,缓存、分布式锁;缓存穿透、缓存击穿、缓存雪崩;双写一致,Canal,Redis持久化,数据过期策略,数据淘汰策略
下一篇
无影云桌面