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

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

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

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

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

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

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

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

docker

问题五:锁的可重入 

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

你可能感兴趣的:(redis)