问题一:获取到锁的线程的对应主机挂了,这时无法释放锁,其他的主机也无法获取锁
设置锁过期时间,到了一定时间就释放锁
问题二: 获取到锁的线程执行业务代码时间超过锁的过期时间,这会造成其他线程也能竞争到锁,这时有两把锁,会造成脏数据
锁续命:延长过期时间 expire(lock, time)
问题三:redis主从问题,获取锁时,数据未同步到从机,导致锁丢失
redlock:原理与zookeeper分布式锁原理相同.多台主机超过半数设置成功则获取锁成功,要注意下主机个数必须是奇数,不过这有效率问题
问题四:并发数达不到多台主机的要求
docker
问题五:锁的可重入
key value的结构:(uuid:线程id : 状态值),重入一次状态值加1,退出减一