• 「网络之概念」短连接、轮询、长轮询(comet)、长连接


    前言

    经常听到:短连接、长连接轮询、长轮询(comet),都是些啥。

    http短连接

    HTTP 协议采用的是「请求-应答」的模式,也就是客户端发起了请求,服务端才会返回响应,一来一回这样子。

    由于 HTTP 是基于 TCP 传输协议实现的,客户端与服务端要进行 HTTP 通信前,需要先建立 TCP 连接,然后客户端发送 HTTP 请求,服务端收到后就返回响应,至此「请求-应答」的模式就完成了,随后就会释放 TCP 连接。

     

    如果每次请求都要经历这样的过程:建立 TCP -> 请求资源 -> 响应资源 -> 释放连接,那么此方式就是 HTTP 短连接,如下图:

    这样实在太累人了,一次连接只能请求一次资源。

    能不能在第一个 HTTP 请求完后,先不断开 TCP 连接,让后续的 HTTP 请求继续使用此连接?

    当然可以,HTTP 的 Keep-Alive 就是实现了这个功能,可以使用同一个 TCP 连接来发送和接收多个 HTTP 请求/应答,避免了连接建立和释放的开销,这个方法称为 HTTP 长连接

    HTTP 长连接

    HTTP 长连接的特点是,只要任意一端没有明确提出断开连接,则保持 TCP 连接状态。

    怎么才能使用 HTTP 的 Keep-Alive 功能?

    在 HTTP 1.0 中默认是关闭的,如果浏览器要开启 Keep-Alive,它必须在请求的包头中添加:

    Connection: Keep-Alive

    然后当服务器收到请求,作出回应的时候,它也添加一个头在响应中:

    Connection: Keep-Alive

    这样做,连接就不会中断,而是保持连接。当客户端发送另一个请求时,它会使用同一个连接。这一直继续到客户端或服务器端提出断开连接。

    从 HTTP 1.1 开始, 就默认是开启了 Keep-Alive,如果要关闭 Keep-Alive,需要在 HTTP 请求的包头里添加:

    Connection:close

    现在大多数浏览器都默认是使用 HTTP/1.1,所以 Keep-Alive 都是默认打开的。一旦客户端和服务端达成协议,那么长连接就建立好了。

    所以,HTTP 长连接减少了 TCP 连接资源的开销。

    可能有的同学会问,如果使用了 HTTP 长连接,如果客户端完成一个 HTTP 请求后,就不再发起新的请求,此时这个 TCP 连接一直占用着不是挺浪费资源的吗?

    对没错,所以为了避免资源浪费的情况,web 服务软件一般都会提供 keepalive_timeout 参数,用来指定 HTTP 长连接的超时时间。

    比如设置了 HTTP 长连接的超时时间是 60 秒,web 服务软件就会启动一个定时器,如果客户端在完后一个 HTTP 请求后,在 60 秒内都没有再发起新的请求,定时器的时间一到,就会触发回调函数来释放该连接。


    轮询

    很多网站为了实现推送技术,所用的技术都是轮询。轮询是在特定的的时间间隔(如每1秒),由客户端浏览器对服务器发出HTTP请求,然后由服务器返回最新的数据给客户端的浏览器。

    优点:后端编码比较简单 缺点:这种传统的模式带来很明显的缺点,即客户端的浏览器需要不断的向服务器发出请求,然而HTTP请求可能包含较长的头部,其中真正有效的数据可能只是很小的一部分,显然这样会浪费很多的带宽等资源。

    长轮询

    客户端向发起一个到服务端的请求,然后服务端一直保持连接打开,直到数据发送到客户端为止。

    优点:避免了服务端在没有信息更新时的频繁请求,节省流量

    缺点:服务器一直保持连接会消耗资源,需要同时维护多个线程,而服务器所能承载的 TCP 连接是有上限的,所以这种轮询很容易导致连接上限。但是后面有了severlet3之后,可以实现异步的长轮询,这也让长轮询变得被很多著名框架采用。

     参考:

    轮询、长轮询、长连接、WebSocket - 腾讯云开发者社区-腾讯云

    网络连接中的长连接和短链接是什么意思? - 知乎

  • 相关阅读:
    从某达OA到Yii2框架的cookie反序列化漏洞研究
    JS 使用Math 方法 获取数组最大值、最小值
    Elasticsearch概述,安装并使用
    对话 Gear|波卡生态下一代 WASM 智能合约平台
    丝网印刷的种类及其应用方法
    孙卫琴的《精通JPA与Hibernate》的读书笔记:通过JPA处理Blob和Clob类型的数据
    K8S-存储卷,pv,pvc
    (中)苹果有开源,但又怎样呢?
    Python 爬虫实战
    小红书账号管理软件,批量账号发布笔记!
  • 原文地址:https://blog.csdn.net/qq_35789269/article/details/127975190