运输层是用来两台主机应用进程之间提供端到端之间的逻辑通信,运输层有两个主要协议TCP和UDP。
1.用户数据报协议UDP
UDP全称是User Datagram Protocol,即用户数据报协议,UDP只是在IP数据报服务上加了很少一点功能,即复用和分用以及差错检测的功能,主要特点有:
- UDP的无连接的,即发送数据报之前不需要建立连接,因此减少了开销和发送数据报之前的时延。
- UDP使用最大努力交付,即不保证可靠交付,因此主机不需要维持复杂的连接状态表(其中有很多参数)
- UDP是面向报文的。发送方的UDP对应用层交下来的报文,在添加首部后就交付给IP层。
- UDP没有拥塞控制,因此网络出现的拥塞不会使源主机的发送率降低
- UDP支持一对一,一对多,多对一和多对多的交互通信
- UDP的首部开销小,只有8字节,而TCP有20字节
下面看下UDP的报文格式
首部有四个字段,每个字段都是两个子节
源端口:源端口号,在需要对方回信时选用,不需要时可全用0
目的端口:目的的端口号,在终点交付时使用
长度:UDP用户数据报的长度,其最小值为8(仅首部)
校验和:检测UDP用户数据报在传输中是否有错,有错就丢弃。
下面有个12字节的伪首部是干嘛的呢?
所谓的“伪首部”表明这种伪首部并不是UDP用户数据报真正的首部,只是在计算检验和时,临时添加到UDP数据报前面,得到一个临时的UDP数据报。检验和就是按照这个临时添加后UDP数据报(检验和字段的范围包括首部和数据这两部分)来计算的。伪首部既不向上提交,又不向下发送,仅仅是为了计算检验和。
2.传输控制协议TCP
TCP(Transmission Control Protocol),传输控制协议,相对UDP来说比较复杂,主要特点如下:
- TCP是面向连接的运输层协议。也就是说应用程序在使用TCP协议前,必须先建立TCP连接,在传输完数据后,必须释放已建立的连接。
- 每一条TCP连接只能有两个端点,每一条TCP连接只能是点对点(一对一)的
- TCP提供可靠交付的服务。通过TCP连接的数据,无差错,不丢失,不重复,而且按序到达
- TCP提供全双工通信。TCP允许通信双方的应用进程在任何时候都能发送数据。TCP两端都设有发送缓存和接收缓存,用来存放双向通信的数据
- 面向字节流。TCP中的”流“指的是流入到进程或从进程流出的字节序列。虽然应用程序和TCP的交互是一次一个数据块(大小不等),但TCP把应用程序交下来的数据仅看成一连串的无结构的字节流。
TCP的报文格式
TCP虽然是面向字节流的,但TCP传输的数据单元却是报文段。
TCP首部20字节是固定的,其包含了一下固定字段:
- 目的端口与源端口: 各占两字节,和UDP的作用类似
- 序号:占4字节,序号范围【0,
-1】,当序号增长到
-1后,下一个序号就重新回到0。TCP是面向字节流的,在一个TCP连接的字节流中的每一个字节都按照顺序编号。整个要传送的数据的起始序号必须在连接建立时设置。首部的序号就是本报文段所发送的数据的第一个字节的序号
-
确认号:占4字节,是期望收到对方下一个报文段的第一个数据字节的序号;若序列号为N,则表明:到序号N-1为止的所有数据报都已正确收到
-
数据偏离:占4位,它指出TCP报文段的数据起始处距离TCP报文段起始处有多远。这个字段实际指出了TCP报文段的首部长度。
-
保留 :占6位保留为今后使用,但目前应置为0
-
紧急URG:当URG=1时,表明紧急字段有效,他告诉系统此报文段中有紧急数据,应尽快传送,直接插队到本报文段数据的最前面
-
确认ACK:仅当ACK=1时确认号字段才有效,当ACK=0时确认号无效。TCP规定,在连接后所有传送的报文段都必须把ACK置为1
-
推送PSH:当两个应用进程进行交互式