Redis实现分布式锁之----超时和失效(非原子性)问题----解决方案

Redis实现分布式锁之----超时和失效(非原子性)问题----解决方案

超时和失效(非原子性)问题

原子性问题 :上锁时存入线程名称,删除时要先判断锁内的名称是不是自己的,是再删除,但是后面的判断和删除非原子性 ,会有并发安全问题。
不可重入问题 :一个线程只能获取一次锁,之后就无法再获取了就是不可重入
失败重试问题 :synchronized获取锁失败会阻塞,当前使用redis,setnx失败就返回了
一致性问题 :Redis主从集群,主节点set锁之后,从节点还没同步时,主节点宕机,从节点变为主节点,这样其他线程也可以获取锁

解决方案

LUA脚本 :使用LUA脚本可以把多条命令作为一条命令执行,使其具有原子性
Watch Dog :看门狗机制,会一直查看锁的过期时间,任务只要没执行完,就会再重置锁的时间
HASH重入次数 :synchronized可重入是内部记录了锁名称和进入锁的次数,Redis使用hash结构可以实现
pub sub :解决失败重试,获取锁失败将锁放入失败队列,获取锁成功通知失败队列让其再去获取锁
RedLock :Redis提供的解决分布式数据一致性问题的算法.

相关推荐
寂寞旅行5 小时前
向量数据库Milvus的使用
数据库·milvus
闻哥6 小时前
Redis事务详解
java·数据库·spring boot·redis·缓存·面试
道亦无名6 小时前
aiPbMgrSendAck
java·网络·数据库
面向对象World9 小时前
正点原子Mini Linux 4.3寸800x480触摸屏gt115x驱动
linux·服务器·数据库
dinga198510269 小时前
mysql之联合索引
数据库·mysql
洛豳枭薰9 小时前
分布式事务进阶
分布式
微风中的麦穗10 小时前
【SQL Server 2019】企业级数据库系统—数据库SQL Server 2019保姆级详细图文下载安装完全指南
大数据·数据库·sqlserver·云计算·个人开发·运维必备·sqlserver2019
无心水10 小时前
5、微服务快速启航:基于Pig与BladeX构建高可用分布式系统实战
服务器·分布式·后端·spring·微服务·云原生·架构
zjttsh11 小时前
MySQL加减间隔时间函数DATE_ADD和DATE_SUB的详解
android·数据库·mysql
顾北1211 小时前
SpringCloud 系列 04:Gateway 断言 / 过滤器 / 限流 一站式落地指南
java·开发语言·数据库