什么是传输层?
传输层
在tcp/ip分层模型中的第二层,OSI七层模型中的第四层。
主要协议为TCP和UDP,TCP可靠传输,UDP不可靠传输
传输层和网络层的区别:
传输层负责将数据可靠地传送到相应的端口(端到端)
网络层根据网络地址将源结点发出的数据包传送到目的结点(点到点)
套接字和端口号
什么是套接字?
套接字是传输层与应用层之间传递数据的门户
传输层实际上并没有直接将数据交付给上层进程,而是将数据交给了一个中间的套接字
,由套接字将数据转交给进程
什么是端口号
端口号是套接字的唯一标识
为了区分每个套接字,为每个套接字设置一个端口号
作为唯一标识
。
比如TCP将数据给到端口号为80的套接字,然后给到http手里。
注意,端口号只具有本地意义,不同计算机的相同端口号没有联系。
TCP和UDP对比
- 连接
TCP 是面向连接的传输层协议,传输数据前要先建立连接。
UDP 是不需要连接,立刻传输数据。
- 可靠性
TCP 是可靠交付数据的,提供拥塞控制、流量控制,数据可以无差错、不丢失、不重复、按需到达。
UDP 是尽最大努力交付,不保证可靠交付数据。
- 服务对象
TCP 是一对一的两点服务,即一条连接只有两个端点。
UDP 支持一对一、一对多、多对多的交互通信
- 应用场景:
-
由于 TCP 是面向连接,能保证数据的可靠性交付,用于对
画质要求高
但是可以缓存所以对实时性要求不高
的场景,例如视频播放等大多数网站 -
由于 UDP 面向无连接,它可以随时发送数据,再加上UDP本身的处理既简单又高效
因此经常用于:游戏、直播等对实时性要求高
的场景
分别使用TCP和UDP的应用层协议:
UDP的报文结构
UDP首部只有4个字段,每个字段占用两个字节。
- 报文长度
表示 UDP 数据报长度,包含 UDP 报文头和数据长度。因为 UDP 报文头长度是 8 个字节,所以这个值最小为 8,最大长度为 65535 字节。 - 校验和:
校验和字段用来校验报文段在传输的过程中是否出现了差错
UDP伪首部
什么是伪首部?
在 TCP或 UDP 的数据报中,在数据报首部前面增加源 IP 地址、目的 IP 地址、IP 分组的协议字段、TCP 或 UDP 数据报的总长度
等共12字节,所构成的扩展首部结构
就是伪首部。
为什么要有伪首部?
此伪首部是一个临时的结构
,它既不向上也不向下传递,仅仅只是为了保证可以校验数据报的正确性
具体怎么校验过程:
将UDP伪首部、首部、数据每16位一组进行二进制反码求和,再将求和结果求反码,填入校验和字段
udp怎么实现可靠传输?
参考
怎么实现可靠传输?
传输层无法保证数据的可靠传输,但是可以通过应用层来实现。实现的方式可以参照tcp可靠性传输的方式,只是实现不在传输层,而是转移到了应用层。
最简单的方式是在应用层模仿传输层TCP的可靠性传输。
可靠UDP的简单设计如下:
1、添加seq/ack机制,确保数据发送到对端
2、添加发送和接收缓冲区
3、添加超时重传机制。
发送端发送数据时,生成一个随机seq=x,然后每一片按照数据大小分配seq。数据到达接收端后接收端放入缓存,并发送一个ack=x的包,表示对方已经收到了数据。发送端收到了ack包后,删除缓冲区对应的数据。时间到后,定时任务检查是否需要重传数据。
MTU和MSS
- MTU (Max Transmission Unit):一个网络包的最大长度
- MSS(Max Segment Size):一个网络包所能容纳的
应用层数据
的最大长度;
以太网的网络包的数据范围:[46,1500]
所以以太网的 MTU
就是1500
为什么需要MTU和MSS
因为数据链路层
传输的帧大小是有限制的,不能把一个太大的包直接塞给链路层,所以需要限制ip报文大小。