html - HTML WebSockets 是否为每个客户端维护一个开放的连接?这个规模吗?

标签 html websocket

我很好奇是否有人知道有关 HTML WebSockets 的可扩展性的任何信息。对于我读过的所有内容,似乎每个客户端都将与服务器保持开放的通信线路。我只是想知道它是如何扩展的以及服务器可以处理多少个打开的 WebSocket 连接。也许让这些连接处于打开状态实际上不是问题,但感觉就是这样。

最佳答案

在大多数情况下,WebSocket 的扩展性可能比 AJAX/HTML 请求更好。然而,这并不意味着 WebSockets 可以替代 AJAX/HTML 的所有用途。

就服务器资源而言,每个 TCP 连接本身消耗的资源非常少。通常建立连接可能很昂贵,但保持空闲连接几乎是免费的。通常遇到的第一个限制是可以同时打开的文件描述符(套接字消耗文件描述符)的最大数量。这通常默认为 1024,但可以轻松配置为更高。

曾经尝试过配置 Web 服务器以支持数以万计的同时 AJAX 客户端吗?将这些客户端更改为 WebSockets 客户端,这可能是可行的。

HTTP 连接虽然不会创建打开的文件或长时间使用端口号,但在几乎所有其他方面都更加昂贵:

  • 每个 HTTP 连接都有很多大部分时间不使用的包袱:cookie、内容类型、内容长度、用户代理、服务器 ID、日期、最后修改时间等。连接建立后,只需要来回发送应用所需的数据。

  • 通常,HTTP 服务器被配置为记录每个占用磁盘和 CPU 时间的 HTTP 请求的开始和完成。记录 WebSockets 数据的开始和完成将成为标准,但是当 WebSockets 连接进行双工传输时,不会有任何额外的记录开销(除非应用程序/服务被设计为这样做)。

  • 通常,使用 AJAX 的交互式应用程序要么连续轮询,要么使用某种长轮询机制。 WebSockets 是一种更简洁(且资源更少)的方式,可以创建更多事件模型,其中服务器和客户端在通过现有连接有要报告的内容时相互通知。

  • 生产环境中大多数流行的 Web 服务器都有一个用于处理 HTTP 请求的进程(或线程)池。随着压力的增加,池的大小将增加,因为每个进程/线程一次处理一个 HTTP 请求。每个额外的进程/线程使用更多的内存,并且创建新的进程/线程比创建新的套接字连接(这些进程/线程仍然必须这样做)要昂贵得多。大多数流行的 WebSockets 服务器框架都采用事件路线,这种路线往往可以扩展并表现得更好。

WebSockets 的主要好处是交互式 Web 应用程序的连接延迟较低。它将比 HTTP AJAX/long-poll 更好地扩展并消耗更少的服务器资源(假设应用程序/服务器设计正确),但 IMO 较低的延迟是 WebSockets 的主要好处,因为它将启用不可能的新类 Web 应用程序AJAX/长轮询的当前开销和延迟。

一旦 WebSockets 标准变得更加最终并获得更广泛的支持,将它用于大多数需要与服务器频繁通信的新交互式 Web 应用程序将是有意义的。对于现有的交互式 Web 应用程序,它实际上取决于当前 AJAX/长轮询模型的工作情况。转换的努力将是非常重要的,因此在许多情况下,付出的代价是不值得的。

更新:

有用的链接:600k concurrent websocket connections on AWS using Node.js

关于html - HTML WebSockets 是否为每个客户端维护一个开放的连接?这个规模吗?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/4852702/

相关文章:

JavaScript:根据选择的 <option> 在包含 <select> 的表中设置 <td> 的背景颜色

html - 在设备独立单位中定义 css 宽度/高度?

html - 如何让图片和文字并排显示

websocket - GKE Ingress 在使用 https 时丢弃 websocket 连接

android - Tyrus Websockets 安卓 : Failed resolving Lorg/glassfish/tyrus/core/OsgiRegistry

android - 如何使用 Retrofit + RX 实现 WebSocket

html - 如何在不移动相邻元素的情况下扩展textarea

websocket - IBM Watson 语音到文本 API 中的 1006 错误代码

node.js - AWS API网关WebSocket API : how to use it with React/NodeJS/native WebSocket?

html - 如何去除行内li元素的默认外边距?