Redis分布式锁的问题以及解决方案
问题一:获取到锁的线程的对应主机挂了,这时无法释放锁,其他的主机也无法获取锁
设置锁过期时间,到了一定时间就释放锁
问题二: 获取到锁的线程执行业务代码时间超过锁的过期时间,这会造成其他线程也能竞争到锁,这时有两把锁,会造成脏数据
锁续命:延长过期时间 expire(lock, time)
问题三:redis主从问题,获取锁时,数据未同步到从机,导致锁丢失
redlock:原理与zookeeper分布式锁原理相同.多台主机超过半数设置成功则获取锁成功,要注意下主机个数必须是奇数,不过这.
原创
2021-02-05 14:53:18 ·
1745 阅读 ·
0 评论