《HTTP权威指南》4-连接管理

时间:2023-12-19 15:11:44

TCP连接

TCP/IP是全球计算机及网络设备都在使用的一种常见的分组交换网络分层协议集
客户端应用程序可以打开一条TCP/IP连接。连接到可能运行在世界任何地方的服务器应用程序

TCP的可靠数据管道

HTTP连接实际上就是TCP连接和一些使用连接的规则
TCP为HTTP提供了一条可靠的比特传输管道
从TCP连接一端填入的字节会从另一端以原有的顺序,正确的传送出来

TCP流是分段的,由IP分组传送

HTTP要传送一条报文时,会进行如下传送:

  1. 以流的形式将报文数据的内容通过一条打开的TCP连接按序传输
  2. TCP接收到数据流后,将数据流砍成被称作段的小数据块
  3. 将段封装在IP分组中,通过因特网进行传输

保持TCP连接的正确运行

任意时刻计算机都可以有几条TCP连接处于打开状态,TCP是通过端口号来保持所有这些连接的正确运行的。
TCP连接是通过4个值来是识别的:
<源IP地址、源端口号、目的IP地址、目的端口号>

对TCP性能的考虑

HTTP事务的时延

《HTTP权威指南》4-连接管理
HTTP事务时延有一下几种主要原因:

  1. 从URL中解析IP地址及端口号
  2. 建立TCP连接
  3. 传输请求报文,及服务器处理请求报文
  4. 返回响应报文

TCP网络时延的大小取决于硬件速度,网络和服务器的负载,请求和响应报文的尺寸,客户端和服务器的距离等

HTTP连接的处理

Connection首部

HTTP允许在客户端和最终的源端服务器之间存在一串HTTP中间实体,包括代理,网关,缓存等。
在某些情况下,两个相邻的HTTP应用程序会为它们共享的连接应用一组选项。
HTTP的Connection首部字段中有一个由逗号分隔的连接标签列表,这些标签为此连接指定了一些不会传播到其他连接中去的选项。

  1. 当HTTP应用程序收到一条带有Connection首部的报文时,接收端会接卸发送端请求的所有选项,并将其应用。
  2. 在将此报文转发给下一跳地址之前,删除Connection首部及Connection中列出的所有首部

并行连接

HTTP允许客户端打开多条连接,并行地执行多个HTTP事务

并行连接可能会提高页面的加载速度

《HTTP权威指南》4-连接管理

并行连接不一定会更快

并行连接的速度可能会更快,但不一定总是更快。
当客户端的网络带宽不足时,大部分的时间肯能都是用来传送数据的,一个连接到速度较快的服务器上的HTTP事务很容易好近所有可能用的Modem带宽。
而且,打开大量连接会消耗很多内存资源,从而引发自身的性能问题

并行连接可能让人“感觉”更快一些

当更多的组件对象同时出现在屏幕上,使用户能够看到加载的进展,哪怕速度上没有变化,也会让人感觉更快

持久连接

Web客户端经常会打开同一个站点的连接。
HTTP/1.1允许HTTP设备在事务处理结束之后将TCP连接保持在打开状态,以便为未来的HTTP请求重用现存的连接。
在事务处理结束后仍然保持在打开状态的TCP连接被称为持久连接

管道化连接

HTTP/1.1允许在持久连接上可选地使用请求管道
在响应到达之前,可以将多条请求放入队列。
当第一条请求通过网络流向地球另一端的服务器时,第二条和第三条也可以开始发送了
管道化连接有如下几条限制:

  • 如果HTTP客户端无法确认连接是持久的,就不应该使用管道
  • 必须按照与请求相同的顺序回送HTTP响应
  • HTTP客户端必须做好连接会在任意时刻关闭的准备
  • HTTP客户端不应该用管道化的方式发送会产生副作用的请求,如POST,否则,当出错时,就会存在某些方法永远不会被执行的风险。

几种连接图

《HTTP权威指南》4-连接管理