首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >ServiceStack.Redis -在哨兵模式下支持分片吗?

ServiceStack.Redis -在哨兵模式下支持分片吗?
EN

Stack Overflow用户
提问于 2018-04-30 19:44:15
回答 1查看 300关注 0票数 2

我想实现以下高可用性设置:

  • 2个主节点(充当带有客户端密钥散列的逻辑数据集的碎片)
  • 两个奴隶(每个主人一个)
  • 6个哨兵(每对主从3人)

现在,我知道ServiceStack.Redis提供了通过哨兵连接到redis的api:

代码语言:javascript
复制
new RedisSentinel(sentinelHosts, masterName: "mymaster").Start().

我还熟悉一个ShardedRedisClientManager,它计算哈希键并返回相应的连接池。

但是,我如何将它们组合在一起,以便我的输入将是一个哨兵列表( init)和请求实际数据的关键?是否有内置的支持在哨兵模式下的切分?

EN

回答 1

Stack Overflow用户

发布于 2019-07-03 16:03:59

我将为未来的谷歌员工回答我自己的问题。我们在ServiceStack中只发现了对分片的部分支持,最后得到了以下代码:

  1. new ConsistentHash<RedisSentinelClientManagerWrapper>(clientManagers);
代码语言:javascript
复制
- where RedisSentinelClientManagerWrapper is our own class which holds instance of sentinel client manager and implements GetHashCode()
- clientManagers is a list of all those sentinel manager wrappers (we have only 2 according to requirements).

  1. 当应用程序启动时,我们初始化所有客户端管理器并创建一个ConsistentHash实例。
  2. 当我们需要在redis中获取/设置一些数据时,我们以这种方式从一致的散列中检索redis客户端: var clientManager = consistentHash.GetTarget(key).ClientsManager;var client = clientManager.GetClient();
票数 2
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/50107173

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档