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

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连接状况是否正常。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值