HTTP长连接和短连接

HTTP协议与TCP/IP协议的关系

  http长连接和短连接本质上是TCP长连接和短连接。http属于应用层协议,在传输层使用TCP协议,在网络层使用IP协议,并且顺序与发送顺序一致。TCP协议是可靠的、面向连接的。

HTTP协议是无状态

  无状态指的是对于事务没有处理记忆能力,服务器不知道客户端是什么状态。也就是说,在同一个web站点10分钟前打开一个页面和现在打开一个页面,它们之间是没有任何联系的。HTTP是一个无状态的面向连接的协议,无状态不代表HTTP不能保持TCP连接,更不能代表HTTP使用的UDP协议。

长连接、短连接

  在HTTP/1.0中默认使用的是短连接。也就是说,客户端每次和服务器进行http操作,就会建立一次连接,任务结束连接也就中断。比如,访问某个页面,页面中包含图片、css、js等多个资源,这样的话,会建立多次连接。
  而在HTTP/1.1中,默认使用了长连接,保持连接特性。使用长连接的HTTP协议,会在响应头加入这行代码 Connection:keep-alive。
  在使用长连接的情况下,当一个网页打开完成后,客户端和服务器之间用户传输HTTP数据的TCP连接不会关闭,客户端再次访问这个服务器时,会继续使用这条已经建立的连接。keep-alive不会永久保持连接,他有一个保持时间,可以在不同的服务器软件中设定。实现长连接需要客户端和服务器端都支持长连接。

长连接和短连接的优缺点

  长连接可以省去较多的TCP建立和关闭操作,减少浪费,节约时间。对于频繁请求资源的客户端适合使用长连接。在长连接的应用场景下,client端一般不会主动关闭连接,当client与server之间的连接一直不关闭,随着客户端连接越来越多,server会保持过多连接。这时候server端需要采取一些策略,如关闭一些长时间没有请求发生的连接,这样可以避免一些恶意连接导致server端服务受损;如果条件允许则可以限制每个客户端的最大长连接数,这样可以完全避免恶意的客户端拖垮整体后端服务。

  短连接对于服务器来说管理较为简单,存在的连接都是有用的连接,不需要额外的控制手段。但如果客户请求频繁,将在TCP的建立和关闭操作上浪费较多时间和带宽。

  短连接的操作步骤是:

建立连接——数据传输——关闭连接…建立连接——数据传输——关闭连接

  长连接的操作步骤是:

建立连接——数据传输…(保持连接)…数据传输——关闭连接


参考