1:首先Redis性能变差了,这和zookeeper一样,多台机器都写成功了,才返回,性能会有下降。写了一部分成功,一部分失败,回滚也会造成性能损失。
2:加锁,加锁的时候Redis1节点挂了,Redis2和Redis3成功。

3:如果客户端线程在执行的时候,Redis2实例挂掉了,如果锁没有持久化,那么,那么Redis2的锁也就丢失了。重启后另外一个客户端线程来加锁。
在Redis1和Redis2加锁成功了,那么这个时候就会有两把一样的锁。
4:但是大部分情况下,加锁的时候Redis1、Redis2、Redis3都会加锁,所以99.999999999999999999999%的情况RedLock就是可用的。
为什么RedLock并不能100%解决Redis做分布式锁的问题?
原文:https://www.cnblogs.com/mkl34367803/p/14649897.html