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

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

  •  
  •   helloworld12 · 9 天前 · 646 次点击

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

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

    求教各位大佬

    谢谢

    第 1 条附言  ·  8 天前
    我说的可用性的保证,是 manager 挂掉,导致单点失败

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

    但是,感觉开发能力不够

    有什么解决方式?
    第 2 条附言  ·  8 天前
    https://www.jianshu.com/p/603158ea120b

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

    其实如果直接用 raft 的话也就是解决了这两个问题,一个集群内部探活选举,一个集群状态同步一致
    关于   ·   FAQ   ·   API   ·   我们的愿景   ·   广告投放   ·   鸣谢   ·   实用小工具   ·   3239 人在线   最高记录 3762   ·  
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.1 · 15ms · UTC 07:34 · PVG 15:34 · LAX 00:34 · JFK 03:34
    ♥ Do have faith in what you're doing.
    沪ICP备16043287号-1