AJAX 与 Web Sockets 的往返时间
我想问一下,与标准 HTTP GET 相比,使用 Web 套接字(消息)实现时是否应该期望一些不同的往返时间(向服务器发送一些信息并接收响应)。我假设 Web 套接字已连接并且 DNS 已解析。
据我了解,如果 GET 由底层协议中的多个往返组成,情况会有所不同,对此我不确定。否则我会期待同样的结果。
I would like to ask if I should expect some different round-trip time (sending some information to the server and recieving a response) when implemented with web sockets (message) compared to a standard HTTP GET. I assume that the web socket is already connected and the DNS is resolved.
As far as I understand it it would be different if GET would consist of multiple roundtrips in the underlying protocol, which I'm not sure of. Otherwise I would expect the same results.
如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。
绑定邮箱获取回复消息
由于您还没有绑定你的真实邮箱,如果其他用户或者作者回复了您的评论,将不能在第一时间通知您!
发布评论
评论(2)
WebSocket 的往返时间似乎较短。我在本地和远程服务器上运行了一些测试,平均每次 100 个请求的行程时间:
测试是在服务器上使用 Node.js 和 express 和 socket.io 完成的,在客户端上使用 Chrome 和 socket.io 的库完成的。远程测试通过 3G 连接进行。
更新:在家里,在延迟低得多的连接上,数字有点不同:
这表明延迟对 HTTP 请求的影响比对 WebSocket 连接的影响更大,这可能是因为 HTTP 必须使正如您提到的,需要进行更多往返才能为每个请求重新建立连接。
WebSockets seem to have a lower round trip time. I ran some tests locally and on a remote server, averaging the trip times for 100 requests at a time:
The tests were done with Node.js with express and socket.io on the server, and Chrome with socket.io's library on the client. The remote tests were run over a 3G connection.
Update: At home on a much lower-latency connection, the numbers are a bit different:
This suggests that latency has a larger effect on HTTP requests than on WebSocket connections, which is likely because HTTP has to make a couple more round trips to reestablish a connection for each request, as you mentioned.
这取决于您考虑的初始场景。
示例1:
在一种情况下您已经建立了 HTTP 1.1 连接,在另一种情况下您已经建立了 WebSocket。在这种情况下,这两种情况的往返行程将完全相同,因为在这两种情况下,您都已经建立了 TCP 连接,并且不需要进一步的应用程序握手。 (注意:两种情况发送的数据量会有所不同,但这会影响带宽,而不是延迟,即往返时间)。
示例2:
在一种情况下,您已经建立了 HTTP 1.1 连接(因为也许您刚刚下载了页面中的最后一张图像),而在另一种情况下,没有打开 WebSocket。那么,在这种情况下,通过 HTTP 的往返时间将低于通过 WebSocket 的往返时间。原因是,使用 HTTP,您只需要发送一个 TCP 段并接收一个 TCP 段(单次往返)。使用 WebSockets,您需要设置 TCP 连接并执行 WS 握手,这涉及几次往返。
It depends on the initial scenario you are considering.
Example 1:
You already have an HTTP 1.1 connection in place in one case and a WebSocket already established in the other case. In this scenario the round trip for both cases will be exactly the same, because in both cases you already have the TCP connection established and no further application-handshake is necessary. (Note: the quantity of data sent for the two cases will be different, but this impacts bandwidth, not latency, that is, round-trip time).
Example 2:
You already have an HTTP 1.1 connection in place in one case (because perhaps you just downloaded the last image in your page) and no WebSocket opened in the other case. Well, in this scenario the round-trip time over HTTP will be lower than the round-trip time over WebSocket. The reason is that with HTTP you only need to send a TCP segment and receive a TCP segment (single round trip). With WebSockets you need to set-up the TCP connection and to perform the WS handshake, which involves a few round trips.