V2EX = way to explore
V2EX 是一个关于分享和探索的地方
现在注册
已注册用户请  登录
LosLion
V2EX  ›  程序员

redis cluster 连接问题

  •  
  •   LosLion · 2020-12-01 20:00:48 +08:00 · 1529 次点击
    这是一个创建于 1460 天前的主题,其中的信息可能已经有所发展或是发生改变。

    最近在学 redis, 有个疑问?

    • 假如 3 主 3 从的 redis 分布式集群,程序连接哪一个 redis 主实例进行读写 (3 个)?
    • 假设连接 a 机器 ip:6379 , 如果它宕机了切换到 b 的 6379 ,怎么办?
    • 如果是把所有(6 个实例)都写入某个连接的配置文件? 那么它是如何检测主节点 /副本节点的? 主节点的选举策略?

    刚学 redis, 望各位大神请教...

    7 条回复    2020-12-02 13:27:14 +08:00
    openbsd
        1
    openbsd  
       2020-12-01 22:00:02 +08:00
    没弄过
    难道不是有个自动迁移的虚拟 IP ?
    LosLion
        2
    LosLion  
    OP
       2020-12-01 22:10:29 +08:00
    @openbsd 没有, 网络上的教程都是教搭建, 好像都没有说怎么连接的. 我知道 mysql mha 是这么做的, redis 集群好像不是这么做的
    liaixiao
        3
    liaixiao  
       2020-12-01 23:03:33 +08:00
    第一个问题应该是连接其中一个节点就可以了,它会自动跳的。第二个第三个问题同等大神解答。
    neuliuxi
        4
    neuliuxi  
       2020-12-02 09:13:06 +08:00
    虽然没看过 redis 的源码 但是感觉和 zk 是一样的模式 选择机器连接以及切换都是 redis client 去操作的,同时 client 会拉取主从或者集群的元数据到本地,选举我觉得应该类似 zk 比较谁的 id 大 定一个规则就行
    FinaleZhu
        5
    FinaleZhu  
       2020-12-02 10:57:23 +08:00
    如果节点挂了,应该会通知客户端新的节点 ip 和端口
    主节点的选举策略应该是 raft 吧
    这些应该都是哨兵做的
    julyclyde
        6
    julyclyde  
       2020-12-02 11:27:35 +08:00
    客户端知道 cluster 结构的
    d0m2o08
        7
    d0m2o08  
       2020-12-02 13:27:14 +08:00
    客户端连接集群的时候需要把集群内所有节点的 ip:port 都写进去
    A 挂了客户端自动就换到 B 了
    关于   ·   帮助文档   ·   博客   ·   API   ·   FAQ   ·   实用小工具   ·   2576 人在线   最高记录 6679   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 29ms · UTC 03:19 · PVG 11:19 · LAX 19:19 · JFK 22:19
    Developed with CodeLauncher
    ♥ Do have faith in what you're doing.