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

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

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

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

解决方案

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

相关推荐
程序猿2023几秒前
SQL-性能优化
数据库·sql·性能优化
程序员王天几秒前
SQLite 查询优化实战:从9秒到300毫秒
数据库·electron·sqlite
码农水水1 分钟前
宇树科技Java被问:数据库连接池的工作原理
java·数据库·后端·oracle
yangmf20406 分钟前
INFINI Gateway 助力联想集团 ES 迁移升级
大数据·数据库·elasticsearch·搜索引擎·gateway·全文检索
码农阿豪12 分钟前
MySQL 亿级大表(1.35亿条)安全添加字段实战指南
数据库·mysql·安全
是阿威啊12 分钟前
【maap-analysis】spark离线数仓项目完整的开发流程
大数据·分布式·spark·scala
白日做梦Q17 分钟前
联邦学习与隐私保护深度学习:面向分布式场景的研究热点与实践
人工智能·分布式·深度学习
典龙33017 分钟前
推荐一款开源免费的AI智能数据库工具,支持连接mysql,oracle,postgresql,ssh,redis
数据库·mysql
怎么没有名字注册了啊18 分钟前
VMware 完整版安装 Debian 纯命令行系统(无图形化、超详细全程教程)
linux·服务器·网络·数据库·debian
rchmin23 分钟前
Redis Key过期删除策略详解
java·redis