• 【Web通信】短轮询与长轮询(Long Polling)是什么?


    连载【Web通信—短轮询与长轮询(Long Polling)详解

    早期的很多网站为具备数据推送能力,所在用的技术基本都是HTTP轮询。
    轮询是由由客户端每隔一段时间(如每隔5s)向服务器发出HTTP请求,服务端接收到请求后向客户端返回最新的数据。

    客户端的轮询方式一般为短轮询长轮询

    一、短轮询

    一般是由客户端每隔一段时间(如每隔5s)向服务器发起一次普通 HTTP 请求。
    服务端查询当前接口是否有数据更新,若有数据更新则向客户端返回最新数据,若无则提示客户端无数据更新。
    短轮询
    优点:简单直接,容易实现。
    缺点:请求频率无法很好确定,如果频率较高,那么就会导致服务端压力大;如果请求的频率放低,那么客户端感知变更的及时性就会降低。

    二、长轮询

    一般是由客户端向服务端发出一个设置较长网络超时时间的 HTTP 请求,并在HTTP 连接超时前,不主动断开连接;待客户端超时或有数据返回后,再次建立一个同样的HTTP 请求,重复以上过程。
    长轮询

    在上面长轮询的图中我们看到:

    • 客户端服务端 发起HTTP请求,并且设置了超时时间timeout为90秒,服务端最长的hold时间是80s;
    • 如果80秒内 服务端 有数据变化,则将数据传递给 客户端 ,并主动断开连接;
    • 如果没有数据更新,待 客户端 超时后会主动断开连接,此后 客户端 将重新建立一个新的HTTP连接,并重复上述过程。

    两个时间只是个示例,代表的是服务端hold的时间要小于客户端设置的超时时间。这也很容易理解,如果服务端的hold时间大于客户端设置的超时时间,那么大概率客户端会出现timeout异常,这是非常不优雅的。

    三、总结

    以上两种轮询方式也带来了很明显的缺点:

    • 首先,客户端需要不断的向服务器发出请求,在消耗较多客户端资源的情况下,服务端并不一定有新的数据下发;
    • 其次,HTTP协议请求与回复消息中,需包含较长的头部信息,其中真正有效的数据有可能只占较小的一部分,带来较多的带宽资源消耗。
    • 另外,若服务端在同一时间存在连续频繁的数据变化(例如:聊天室场景中),客户端获知数据更新相对较慢(可能存在时间的滞后性)无法保证客户端的用户体验。

    📢欢迎点赞👍/ 收藏⭐/ 留言📝如有错误敬请指正!
    后续持续更新中…
    下一篇 【Web通信】WebSocket双向通信

  • 相关阅读:
    吃透Redis(八):缓存淘汰篇-LRU算法
    10分钟搞定manim安装与vscode配置
    tomcat 理解请求转发 221108
    spring boot项目如何采用war在tomcat容器中运行呢?
    C语言 数组作为函数参数
    永恒之蓝方程式利用工具使用教程
    Leetcode 199. Binary Tree Right Side View (DFS/BFS好题)
    【Linux常见指令1】
    HTML静态网页作业——基于html+css+javascript+jquery+bootstarp响应式成都家乡介绍网页
    Pytorch的variable和tensor区别
  • 原文地址:https://blog.csdn.net/weixin_42960907/article/details/127666651