node-redlock
node-redlock copied to clipboard
High Availability Failure
Redlock is instantiated with three independent Redis instances. They run on different containers on different ports. When i shutdown one of the instances and try to acquire a lock it simply throws out EAI_AGAIN
errors until i restart the instance and then the lock is successfully acquired or sometimes not.
If it is supposed to failover why does this behaviour exist? Instantiation below
LockService.lock = new Redlock(
[LockService.redis, LockService.redis2, LockService.redis3],
{
driftFactor: LockService.driftFactor, //all default values from repo
retryCount: LockService.retryCount,
retryDelay: LockService.retryDelay,
retryJitter: LockService.retryJitter,
automaticExtensionThreshold:
LockService.automaticExtensionThreshold,
}
);
After Shutting down one instance:
data:image/s3,"s3://crabby-images/7a845/7a8451fcdeacf999d3b6ade4b30a221a3be4eb1b" alt="Screenshot 2023-02-04 181404"
After restarting instance:
data:image/s3,"s3://crabby-images/dcdb3/dcdb364a5ca13288864e1360f0425244f519e650" alt="Screenshot_20230204_063426"