Redlock 与 redis-ha 集群

TGH*_*TGH 6 c# redis stackexchange.redis redis-cluster redlock.net

我一直在尝试根据 Helm Chart 中安装在 kubernetes 中的 Redis 集群来配置分布式 RedLock stable/redis-ha。理想情况下,我希望集群有多个副本(主/辅助复制)。

我正在遵循使用 StackExchangeRedis 和 Redlock.Net 进行设置的标准示例

ConnectionMultiplexer redis = ConnectionMultiplexer.Connect("localhost:6379");

var multiplexers = new List<RedLockMultiplexer>
{
    redis
};

var redlockFactory = RedLockFactory.Create(multiplexers);

var resource = "the-thing-we-are-locking-on";
var expiry = TimeSpan.FromSeconds(30);

using (var redLock = await redlockFactory.CreateLockAsync(resource, expiry))
{
    //This is almost always false and the lock status is NoQuorum
    if (redLock.IsAcquired)
    {
        
    }
    
}
Run Code Online (Sandbox Code Playgroud)

我看到的行为是,即使在单用户环境中,通常也不会获取锁。状态为 NoQuorum,这表明 RedLock .Net 无法获得多数票,但在我当前的测试集群中,我只有一个副本。我已经让它工作了几次,但它通常不稳定并且随机停止工作。

我已经找到了关于集群锁定的部分https://github.com/samcook/RedLock.net

基本上我的理解是有基本的支持,但是你必须直接连接到集群中的所有副本。

以前有人成功地针对集群配置过分布式锁定吗?

jjx*_*tra 0

我曾与 Polly 人员合作开发重复请求折叠器(https://github.com/Polly-Contrib/Polly.Contrib.DuplicateRequestCollapser)。我还使用 redis 创建了一个分布式锁版本(https://github.com/Polly-Contrib/Polly.Contrib.DuplicateRequestCollapser.RedisDistributedLock)。

我对 Redis 集群不太熟悉,但是如果它们涉及某种分片,则需要在继续操作之前获取集群每个分片上的分布式锁。

这两个都应该有 nuget 包。让我知道这是否有帮助。