Redis分布式锁的问题以及解决方案

问题一:获取到锁的线程的对应主机挂了,这时无法释放锁,其他的主机也无法获取锁

设置锁过期时间,到了一定时间就释放锁

问题二: 获取到锁的线程执行业务代码时间超过锁的过期时间,这会造成其他线程也能竞争到锁,这时有两把锁,会造成脏数据

锁续命:延长过期时间  expire(lock, time)

问题三:redis主从问题,获取锁时,数据未同步到从机,导致锁丢失

redlock:原理与zookeeper分布式锁原理相同.多台主机超过半数设置成功则获取锁成功,要注意下主机个数必须是奇数,不过这有效率问题

 问题四:并发数达不到多台主机的要求

docker

问题五:锁的可重入 

key value的结构:(uuid:线程id  :   状态值),重入一次状态值加1,退出减一

  • 2
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值