1、网络分层
标准分层为7层模型,物理层、数据链路层、网络层、会话层、表示层、应用层。之所以要分为这么多层,是为了扩展性和标准化。我通常是这样记忆的:物数(兀术)网传 会表应)(回表营)。
使用时UDP、TCP可以直接使用简化的四层模型
2、传输层数据传输路径
在传输数据时,用户数据首先添加应用层协议的头部APPL头部(应用层是如http协议这种,指的就是http头部),长度根据具体情景不同。
接着添加传输层头部(TCP、IP头部),长度。
接着添加网络层头部(IP头部)。
接着添加以太网头部。
最后通过物理连接发送。
2.1UDP首部长度
UDP首部长度是固定的,8个字节,包含上述信息。部分同志说UDP首部长度是20字节,是因为算上了假首部12个字节。但是假首部只是在传输层用于计算校验和,不参与实际的UDP数据报传输,因而真实长度是8字节。
ps:由于数据总长度字段只有16位,因此,单次只能传输小于64K字节数据。
2.2TCP首部长度
TCP首部长度最短20字节、最长60字节,区别在于选项和填充区域有多大。
2.2IP首部长度
同上,IP首部长度最短20字节、最长60字节,区别在于选项和填充区域有多大。
3、数据链路层数据传输
3.1以太网首部长度
以太网首部长度14字节,尾部4字节。
3.2以太网最大传输单元MTU
1、在链路层,由以太网的物理特性决定了数据帧的长度为(46+18)-(1500+18),其中的18是以太网数据帧的头和尾,也就是说数据帧的内容最大为1500(不包括帧头和帧尾),即MTU(Maximum Transmission Unit)为1500;
2、在网络层,因为IP包的首部要占用20字节,所以这的MTU为1500-20=1480;
3、在传输层,对于UDP包的首部要占用8字节,所以这的MTU为1480-8=1472;
所以,在应用层,Data最大长度为1472。当我们的UDP包中的数据多于MTU(1472)时,发送方的IP层需要分片fragmentation进行传输,而在接收方IP层则需要进行数据报重组,由于UDP是不可靠的传输协议,如果分片丢失导致重组失败,将导致UDP数据包被丢弃。
3.3数据分段和分片
1、 分段特指发生在使用TCP协议的传输层中的数据切分行为
2、分片特指发生在使用IPv4协议的网络IP层中的数据切分行为
3、UDP发送数据超过MTU,但小于64K时,通过在网络层将数据分片,然后发出。
4、TCP数据超过MTU时,在传输层进行分段,发出。TCP包头中就没有“包长度”字段,而完全依靠IP层去处理分帧。这就是为什么TCP常常被称作一种“流协议”的原因,开发者在使用TCP服务的时候,不必去关心数据包的大小,只需讲SOCKET看作一条数据流的入口,往里面放数据就是了,TCP协议本身会进行拥塞/流量控制。