传输层的基本服务
一、传输层的功能
传输层的核心任务是为应用进程之间提供。
1. 主要功能包括:
传输层寻址
应用层报文的分段和重组
报文的差错检测
进程间的端到端可靠数据传输控制
面向应用层实现复用与分解
端到端的流量控制
拥塞控制
2. 传输层提供的服务
传输层协议提供服务;
传输层协议只需在中实现;
通信的真正端点并不是主机,而是主机中运行的。
二、传输层寻址与端口
1. 用统一的寻址方法对应用进程进行标识——。
2. 在全网范围内利用 "" 唯一标识一个通信端点。(即应用进程)
3. 传输层端口号为16位整数,包含三类端口:
(1),数值为 0~1023.
(2),数值为 1024~49151,为没有熟知端口号的应用程序使用。使用这个范围的端口号必须在IANA登记,以防止重复。
(3),数值为 49152~65535,留给客户进程选择暂时使用。
提供服务的人端口号一定要固定,但对于用户来说无所谓。
三、无连接服务与面向连接服务
1. 无连接服务——数据传输之间无需与对端进行任何信息交换(即 “握手”),直接构造传输层报文段并向接收端发送。 ——UDP
2. 面向连接服务——在数据传输之前,需要双方交换一些控制信息,,然后再,数据传输结束后还需要再。 ——TCP
传输层的复用与分解
多路复用与多路分解:是传输层的一项基本功能,支持众多应用进程共用同一个传输层协议,并能够将接收到的数据准确交付给不同的应用进程。
一、无连接的多路复用与多路分解
UDP套接字:<目的IP地址,目的端口号>
UDP套接字的端口号是UDP实现复用与分解的重要依据。
通过目的IP地址可以判断到哪个主机,通过目的端口可以判断到哪个应用进程。
二、面向连接的多路复用与多路分解
TCP套接字(标识一条TCP连接):
<源IP地址,源端口号,目的IP地址,目的端口号>
当一个TCP报文段从网络层到达一台主机时,该主机根据这 4 个值来将报文段分解到相应的套接字。
停-等协议与滑动窗口协议
一、可靠数据传输基本原理
实现可靠数据传输的措施:
1. 差错检测:利用差错编码实现数据包传输过程中的比特差错检测。
2. 确认:接收方向发送方反馈接收状态。
3. 重传:发送方重新发送接收方没有正确接收的数据。
4. 序号:确保数据按序提交。
5. 计时器:解决数据丢失问题。
二、停-等协议
停-等协议的主要特点就是每发送一个报文段后就停下来等待接收方的确认。
停-等协议的基本工作过程:
1. 发送方发送经过差错编码和编号的报文段,等待接收方的确认;()
2. 接收方如果正确接收报文段,即差错检测无误且序号正确,则接收报文段,并向发送方发送ACK,否则丢弃报文段,并向发送方发送NAK;()
3. 发送方如果收到ACK,则继续发送后续报文段,否则重发刚刚发送的报文段。()
三、滑动窗口协议
1. 停-等协议的主要性能问题:
停止-等待机制降低了信道利用率。
2.解决方法:
或管道协议——允许发送方在没有收到确认前连续发送多个分组。
3. 流水线协议的改进:
增加分组序号范围;
发送方和(或)接收方必须。
4. 典型的流水线协议:
滑动窗口协议
停-等协议发送端每发送一个报文就需要停下来等待对方确认,相当于发送窗口大小为1;接收端仅接收符合当前预期的一个报文,接收窗口大小为1.
三、滑动窗口协议
两种最具有代表性的滑动窗口协议:
1. 回退N步(Go-Back-N,GBN)协议:
发送端窗口大小较大,可以在未得到确认前连续发送多个分组;但接收窗口大小仅为一,只能接收1个按序到达的分组,未按序到达的分组或者某个分组差错,就会引起发送方重发该分组及其之后的所有分组。
2. 选择重传(Selective Repeat,SR)协议:
增加接收方缓存能力(接收窗口>1),缓存正确到达但失序的分组,仅要求发送方重传未被接收方确认的分组,等缺失分组到达后一并向上层按序提交。
用户数据报协议(UDP)
用户数据报协议UDP是Internet传输层协议,提供、、数据报尽力传输服务。
一、UDP数据报结构
1. 源和目的端口号:用于UDP实现复用与分解。
2. 长度字段:在UDP报文段中的字节数(首部和数据的总和)。
3.校验和:接收方用来检测该报文段是否出现了差错。
二、UDP校验和
计算校验和:
1. 对所有参与运算的内容(包括UDP报文段)按16位(16位对齐)求和;
2. 求和过程中遇到的任何溢出(即进位)都被回卷(即进位与和的最低位再加);
3. 最后得到的和取反码。
传输控制协议(TCP)
一、TCP报文段结构
源端口(2字节):发送端应用程序的端口号.
目的端口(2字节):接收端应用程序的端口号.
序号(4个字节):TCP是面向字节流传输的,他为每一个字节编了一个序号,该报文段中序号为传输数据第一个字节的序号。例如:一个报文端的数据部分大小为100个字节,他的序号为400,那么下一次报文段的序号就为500.
确认号(4个字节):指明了下一个期待接收的字节序号,表明该序号之前的所有字节都正确接收到了,只有当ACK为 1 的时候确认号才有效.
数据偏移/首部长度(4个字节): 用来表示报文段数据的起始处距离报文起始处的长度,也就是TCP报文首部的长度,由于首部含有可选项,所以TCP报头长度是不确定的.
保留:为了将来定义新的用途保留,现在一般都置为0.
URG紧急控制位:与紧急指针配合使用,当URG为1的时候,就是通知系统这个报文段有紧急数据,需要优先传输。
ACK确认控制位:当它为 1 的时候,确认号字段才有效,TCP规定,在连接建立后,所有ACK都应该置为1
PSH推送控制位:当报文段的psh为 1 的时候,接收方接到该报文段,就立刻将他交付给接收应用进程,而不是等缓存已满的时候再交付。
RST复位控制位:当报文段的RST为1的时候,说明该TCP连接出现错误,必须释放连接,并重新建立连接。
SYN同步控制位:在连接建立时用来同步序列号,当 SYN=1,ACK=0 时说明这是一个连接请求报文段,如果对方同意建立连接则应该在响应的报文段中将 SYN=1,ACK=1,表示接受请求
FIN终止控制位:用来释放连接,当FIN=1时表示此报文段发送方的数据已经发送完毕,并要求释放连接。
窗口(2字节):用来告知发送端,接收端的缓存大小,以此控制发送方发送数据的速率,从而达到流量控制,窗口最大为65536。
校验和:用CRC来校验整个TCP报文段,包括tcp头,tcp数据,由发送端进行计算和存储,接收端进行校验,如果接收方发现校验和有差错,则TCP段会被直接丢弃。
紧急指针(2字节):标识紧急数据在报文段结束的位置。
选项:长度可变,最大长度40个字节
二、TCP连接管理
连接建立——三次握手:
1. SYN连接请求(客户端-->服务端)
2. SYNACK确认(同步确认)
3. ACK确认(客户端再次确认)
TCP三次握手建立连接过程:
TCP断开连接的过程——四次挥手:
三、TCP可靠数据传输
1. TCP的可靠数据传输实现机制包括差错编码、确认、序号、重传、计时器等。
2. TCP的可靠数据传输是基于滑动窗口协议,但是发送窗口大小动态变化。
(1)封装TCP报文段
(2)发出一个报文段后启动一个计时器
(3)通过校验和发现数据差错
(4)通过序号重新排序,丢弃重复的报文段
(5)流量控制
四、TCP流量控制
1. TCP协议利用实现流量控制,但不是简单的滑动窗口协议。
2. TCP连接建立时,双方都为之分配了固定大小的缓冲空间;TCP的接收端只允许另一端发送其缓冲区所能接纳的数据。
(1)接收端在给发送端发送确认段时,通告接收窗口大小。
(2)发送端在接下来发送数据段时,确保未确认段的应用层数据总量不超过接收端通告的接收窗口大小,从而确保接收端不会发生缓存溢出。
五、TCP拥塞控制
1. 窗口机制:
通过调节窗口的大小实现对发送数据速率的调整。
2. 窗口调整的基本策略:
AIMD(Additive Increase,Multiplicative Decrease)加性增加,乘性减小;
网络未发送拥塞时,逐渐 “加性” 增大窗口大小,当网络拥塞时 “乘性” 快速减小窗口大小。
3. TCP的拥塞控制算法:
包括了慢启动、拥塞避免、快速重传和快速恢复4部分。