V2EX = way to explore
V2EX 是一个关于分享和探索的地方
现在注册
已注册用户请  登录
V2EX 提问指南
helloworld12
V2EX  ›  问与答

通过 tcp 连接起来的系统如何保证高可用性?

  •  
  •   helloworld12 · 2018-07-14 09:16:36 +08:00 · 1594 次点击
    这是一个创建于 2084 天前的主题,其中的信息可能已经有所发展或是发生改变。

    https://www.zhihu.com/question/48188201

    知乎上别人的提问,最近在写长连接服务,想要弄个 manager 分配业务服务 IP 给网关,总担心 manager 单点失败... 导致不敢写

    求教各位大佬

    谢谢

    第 1 条附言  ·  2018-07-14 21:17:06 +08:00
    我说的可用性的保证,是 manager 挂掉,导致单点失败

    可能就 paxos/raft 这算法,能保证强一致性,然后多部署几个节点,这样避免单点失败

    但是,感觉开发能力不够

    有什么解决方式?
    第 2 条附言  ·  2018-07-14 21:21:22 +08:00
    https://www.jianshu.com/p/603158ea120b

    这里介绍了, shadow-master 模式, 有个问题,是这两个节点的状态同步,要怎么处理比较合适
    4 条回复    2018-07-15 06:18:11 +08:00
    opengps
        1
    opengps  
       2018-07-14 10:01:35 +08:00 via Android
    连接时候可以用域名,要不就自动寻找第二 ip
    PDX
        2
    PDX  
       2018-07-14 10:19:46 +08:00
    服务端维护 ip 列表,API 获取 ip 列表,连接失败轮询列表。
    innoink
        3
    innoink  
       2018-07-14 13:51:46 +08:00 via Android   ❤️ 1
    paxos/raft?
    faceair
        4
    faceair  
       2018-07-15 06:18:11 +08:00 via iPhone
    你这里的 manager 看起来是无状态的,保证挂了有另一台顶上去就行了吧?
    如果里面有状态的话可以考虑用队列或者直接 tcp 将状态同步给另一台机器同样处理一遍。

    其实如果直接用 raft 的话也就是解决了这两个问题,一个集群内部探活选举,一个集群状态同步一致
    关于   ·   帮助文档   ·   博客   ·   API   ·   FAQ   ·   我们的愿景   ·   实用小工具   ·   1010 人在线   最高记录 6543   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 27ms · UTC 19:56 · PVG 03:56 · LAX 12:56 · JFK 15:56
    Developed with CodeLauncher
    ♥ Do have faith in what you're doing.