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

请教: 信令服务器如何避免单点故障?

  •  
  •   silenzio · 2020-04-10 17:55:01 +08:00 · 2109 次点击
    这是一个创建于 1686 天前的主题,其中的信息可能已经有所发展或是发生改变。

    需求: web 需要和后端集群中的某台服务器建立 webRTC 连接, 由调度服务器来选择一个后端服务器.

    整个系统中目前只有信令服务器是单点了, 请问各位大佬, 如何改善呢?

    9 条回复    2020-04-11 19:03:03 +08:00
    liuxu
        1
    liuxu  
       2020-04-10 21:32:14 +08:00
    前置负载均衡
    heyjei
        2
    heyjei  
       2020-04-10 21:52:02 +08:00 via Android
    把程序和数据分开就可以了。

    调度程序做成无状态的就可以了,数据存 redis 。这样调度程序可以同时运行好几个,前端加一个负载均衡即可; 后端的数据存储用分布式的 redis,
    silenzio
        3
    silenzio  
    OP
       2020-04-10 22:30:10 +08:00 via Android
    @heyjei 调度服务器我就是这么做的 调度相关的数据放内存里 用 etcd 选举 需要持久化的用数据库做双主热备
    silenzio
        4
    silenzio  
    OP
       2020-04-10 22:31:10 +08:00 via Android
    @liuxu 负载均衡是随机分配的吧 web 和后端服务器需要了解到同一个信令才能成功握手
    liuxu
        5
    liuxu  
       2020-04-11 08:32:43 +08:00
    @silenzio #4 不是,看你算法,可以指向一台机器,另一台备用
    twoconk
        6
    twoconk  
       2020-04-11 09:28:58 +08:00
    配置信令代理,信令代理支持集群,SIP 的信令代理可以参考 https://it3q.com/article/55,刚整理的。
    silenzio
        7
    silenzio  
    OP
       2020-04-11 09:49:58 +08:00 via Android
    @liuxu 谢谢 我去查查资料
    silenzio
        8
    silenzio  
    OP
       2020-04-11 09:50:18 +08:00 via Android
    @twoconk 谢谢 我看看笔记
    wnpllrzodiac
        9
    wnpllrzodiac  
       2020-04-11 19:03:03 +08:00 via Android
    redis 集群多节点。不过客户端重连还是要自己做额
    关于   ·   帮助文档   ·   博客   ·   API   ·   FAQ   ·   实用小工具   ·   1190 人在线   最高记录 6679   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 22ms · UTC 23:08 · PVG 07:08 · LAX 15:08 · JFK 18:08
    Developed with CodeLauncher
    ♥ Do have faith in what you're doing.