当前位置 博文首页 > sinat_41938770的博客:HTTP和TCP的Keep-Alive机制的区别

    sinat_41938770的博客:HTTP和TCP的Keep-Alive机制的区别

    作者:[db:作者] 时间:2021-08-22 18:09

    HTTP和TCP中的Keep-Alive机制的区别

    1、HTTP中的Keep-Alive

    HTTP是短连接

    ? 所谓的短连接就是,每次客户端向服务端发送一个HTTP请求(request),得到服务端返回的响应(response),然后这个HTTP连接就关闭了。

    为什么使用短连接

    ? 考虑到性能。用户通过浏览器访问一个web站点的某个网页,当网页内容加载完毕后,用户一般会花费几十秒到几分钟来浏览内容,此时没有必要维持这个HTTP连接。这样做可以减轻服务端的压力。

    HTTP为什么要引入Keep-Alive

    ? 一个网页会有很多组成部分,除了文本内容,还会有js、css、图片等静态资源。如果每次请求一个资源就创建一个连接然后又关闭,消耗的资源太大。

    ? 基于这个背景,HTTP协议中引入了Keep-Alive属性,启用这个属性时,连接在短时间内能够复用。所以当我们在加载同一个网页的资源时,可以尽量复用连接。

    ? Keep-Alive属性在HTTP1.0中是默认关闭的。在HTTP1.1中是默认开启的。

    ? 总结:HTTP引入Keep-Alive,是为了让传输层协议(TCP)存活的时间更久,以便于复用连接。

    2、TCP中的Keep-Alive

    ? 当一个TCP连接建立之后,如果应用程序或者上层协议一直不发送数据,TCP需要通过一种机制来得知,自己是连接中断了,还是对方已经不在线,还是说确实没有数据传输。

    ? 引入Keep-Alive机制,TCP在超过一段时间时(通常默认配置是2小时),会自动发送一个Keep-Alive探针,探测连接是否存活。当一方向另一方发送一个Keep-Alive探针时,会有三种情况:

    ? 1、对方回应了ACK。这说明连接正常,如果接下来的2小时没有数据传输,则还会发送Keep-Alive探针来确保连接是否正常。

    ? 2、对方回应了RST。这说明连接不存在。这种情况可能是,某一方服务宕机,重启之后收到了Keep-Alive探针,则会回复RST,因为重启后不存在对应的连接。

    ? 3、没有回应。这说明对方已经关闭了socket。

    ?

    ? 总结:TCP引入Keep-Alive,是为了检测TCP连接的情况。

    3、总结 对比

    HTTP的Keep-Alive是为了能在短时间内复用连接。

    TCP的Keep-Alive是为了检测TCP连接状况是否正常。

    cs