AskOverflow.Dev

AskOverflow.Dev Logo AskOverflow.Dev Logo

AskOverflow.Dev Navigation

  • 主页
  • 系统&网络
  • Ubuntu
  • Unix
  • DBA
  • Computer
  • Coding
  • LangChain

Mobile menu

Close
  • 主页
  • 系统&网络
    • 最新
    • 热门
    • 标签
  • Ubuntu
    • 最新
    • 热门
    • 标签
  • Unix
    • 最新
    • 标签
  • DBA
    • 最新
    • 标签
  • Computer
    • 最新
    • 标签
  • Coding
    • 最新
    • 标签
主页 / server / 问题 / 642256
Accepted
Bastien974
Bastien974
Asked: 2014-11-06 08:21:24 +0800 CST2014-11-06 08:21:24 +0800 CST 2014-11-06 08:21:24 +0800 CST

为超过 64k 的 websocket 扩展 HAProxy

  • 772

我们正在尝试设计一种能够处理超过 64k 个 websocket 的架构。

我们首先尝试使用 Amazon ELB,但它的设计不允许意外的流量峰值和 websocket。(TCP 模式意外超时 websockets)

使用 HAProxy,这些限制不适用,但我们将限制在 HA 和后端服务器之间维护的 ~64k websockets。

想到的多种解决方案:

  • 多个 HAProxy 实例,使用 DNS 进行负载平衡(Route53 具有加权选项)
  • 两个具有 Keepalived、多个内部 IP 地址的 HAProxy 实例(不确定是否可行)

有一个更好的方法吗 ?

domain-name-system
  • 2 2 个回答
  • 1824 Views

2 个回答

  • Voted
  1. Best Answer
    Kyle Brandt
    2014-11-06T09:17:37+08:002014-11-06T09:17:37+08:00

    如果您的 64k 限制是由于源端口造成的,您可以执行以下操作(有点骇人听闻,但这是我们目前在 SE 为 websockets 做的事情(我们通常与 HAProxy 有 50 万并发):

    server ny-web01-1 10.0.0.1:8081 check
    server ny-web01-2 10.0.0.1:8082 check
    server ny-web01-3 10.0.0.1:8083 check
    

    使用keepalived也可以实现多个实例。只需在多个 IP 上执行类似循环 DNS 的操作。只需确保 IP 始终被活动负载平衡器拾取,因为 DNS 本身不会为您提供负载平衡(这里还有更多选项,这个很简单)。

    • 7
  2. Hrvoje Špoljar
    2014-11-06T08:29:35+08:002014-11-06T08:29:35+08:00

    您可以使用 Anycast 和 BGP 或其他一些边界路由协议设置多个共享相同 IP 的 HAproxy 系统。这样所有的 HAproxy 系统都处于活动状态;如果其中任何一个出现故障,您将停止在该系统上发布 BGP 路由,它将在约 30 秒内停止接收流量;这将被重新分配到其他宣传相同范围的可用系统。

    例如检查这个url 如何设置这样的布局

    • 0

相关问题

  • Solaris DNS

  • resolv.conf 在经过一段时间后被更改

  • 为什么有些网站的网址中没有“www”就无法显示?[关闭]

  • 为本地网络中的名称解析添加自定义 dns 条目

Sidebar

Stats

  • 问题 205573
  • 回答 270741
  • 最佳答案 135370
  • 用户 68524
  • 热门
  • 回答
  • Marko Smith

    新安装后 postgres 的默认超级用户用户名/密码是什么?

    • 5 个回答
  • Marko Smith

    SFTP 使用什么端口?

    • 6 个回答
  • Marko Smith

    命令行列出 Windows Active Directory 组中的用户?

    • 9 个回答
  • Marko Smith

    什么是 Pem 文件,它与其他 OpenSSL 生成的密钥文件格式有何不同?

    • 3 个回答
  • Marko Smith

    如何确定bash变量是否为空?

    • 15 个回答
  • Martin Hope
    Tom Feiner 如何按大小对 du -h 输出进行排序 2009-02-26 05:42:42 +0800 CST
  • Martin Hope
    Noah Goodrich 什么是 Pem 文件,它与其他 OpenSSL 生成的密钥文件格式有何不同? 2009-05-19 18:24:42 +0800 CST
  • Martin Hope
    Brent 如何确定bash变量是否为空? 2009-05-13 09:54:48 +0800 CST
  • Martin Hope
    cletus 您如何找到在 Windows 中打开文件的进程? 2009-05-01 16:47:16 +0800 CST

热门标签

linux nginx windows networking ubuntu domain-name-system amazon-web-services active-directory apache-2.4 ssh

Explore

  • 主页
  • 问题
    • 最新
    • 热门
  • 标签
  • 帮助

Footer

AskOverflow.Dev

关于我们

  • 关于我们
  • 联系我们

Legal Stuff

  • Privacy Policy

Language

  • Pt
  • Server
  • Unix

© 2023 AskOverflow.DEV All Rights Reserve