美文网首页Web前端学习
WEB揭秘之长连接,短连接,长轮询,短轮询

WEB揭秘之长连接,短连接,长轮询,短轮询

作者: Renaissance_ | 来源:发表于2019-01-14 18:50 被阅读0次

    长连接,短连接,长轮询,短轮询都是之间有联系,但是真正的弄懂他们之间的联系是有一定难度的。本文就讲述下他们各自的概念以及简单的实现方式.

    短连接

    客户端与服务端之间建立通信需要经过该三次握手:
    客户端建立连接(发送syn报文)->服务端发送确认信息(发送syn+ack报文)->客户端接收确认信息。因此通过tcp建立了客户端与服务端的连接。
    http通信通过tcp建立连接一般都是短连接,客户端与服务器之间建立了一次通信后就要断开连接,当再次需要进行通信的时候就要再次通过tcp建立连接.


    长连接

    通过tcp建立Http长连接,就解决了短连接的弊端,当建立了客户端和服务器端的连接后,就会保持这个连接,但是不会断开,后续通信可继续使用这个长连接。但是长连接会对服务器端造成非常大的压力,因为长连接不关闭的话会越来越多。解决这种风险可以设置最大长连接数,服务器端也可以关闭一些长时间无操作的连接。


    短轮询

    短轮询是建立在http通信的基础上。当服务器端的数据在实时更新想要向客户端推送时,就会用到轮询这种方式。因为客户端只能主动向服务器端发送请求获取数据,但是要服务端主动发送数据给客户端,就可以在客户端不断的发送请求给服务器端,服务器端不管有没有数据都会返回数据。保持客户端不断发送请求的方法是设置一个定时器不断调用某个函数.
    然而短轮询的缺点也显而易见,这样不断的请求数据就会造成服务器端的压力,并且如果设置超时过短就会获得脏数据.

    实现代码

    <script type="text/javascript">
    $(function () {
    
    window.setInterval(function () {
    
       $.get("${pageContext.request.contextPath}/communication/user/ajax.mvc",
    {"timed": new Date().getTime()},
    function (data) {
      $("#logs").append("[data: " + data + " ]<br/>");
    });
      }, 3000);
    
    });
    </script>
    

    长轮询

    长轮询是对短轮询的一种提升,当客户端不断地向服务器端请求数据的时候,若有数据则返回,没有数据返回的情况都要hold on ,直到timeout。这种解决办法一定程度上解决了服务器端的压力,但是如果进程过多,也会成为问题.

    实现代码

    客户端
    //ajax长轮询
    function PostSubmit(params, success) {
     $.post("comet_broadcast.asyn", params, success, "json");
      }
     function Keepline() {
       var array = new PHPArray("Keepline"); 
       var success = function (data, status) {
       if (data.ResponseStatus == 1) { 
          ShowMessage(data.ResponseData, "recive");
       }
       Keepline(); 
       }
       PostSubmit(array.ToJson(), success);
       }
    

    总结

    这是最近对浏览一些博客最基本的了解,以后如果有更深层次的了解将会继续修改。

    相关文章

      网友评论

        本文标题:WEB揭秘之长连接,短连接,长轮询,短轮询

        本文链接:https://www.haomeiwen.com/subject/pbexrttx.html