网络(五) 传输层

it2024-12-30  13

第五章 传输层

5.1 传输层与UDP

一. 传输层的功能

传输层为应用进程之间提供端到端的逻辑通信传输层要对收到的报文进行差错检验传输层需要2种协议 (1)面向连接的TCP (2)无连接的UDP

二. UDP的特点

UDP是无连接的,即发送数据之前不需要建立连接UDP使用尽最大努力交付,即不保证可靠交付,同时也不实用拥塞控制UDP面向报文,适合多媒体通信需求UDP的首部开销小,只有8字节 校验和字段计算过程:把没32bit作为一项,逐项相加(包括首部和数据),最后不足32bit的项填充0后相加。将这些项的反码求和后再求反码,结果就是校验和字段的值

5.2 TCP

一. TCP的概念

TCP是面向连接的传输层协议每一条TCP连接只能又2个端点 每一条TCP连接只能是点对点的TCP提供可靠交付物反应

TCP提供全双工通信

TCP是面向字节流的 (1)TCP把每个字节都编上了序号 (2)TCP要求把每个序号都发送回ACK报文

TCP报文头 (1)源端口,目的端口占4字节:表示操作系统上的0~\(2^{16}端口范围\) (2)序号:报文第一个字节的序号(4字节) (3)确认号:即将收到的对方返回报文中的序号(这个序号由对方主机维护)(4字节) 【注】:服务端和客户端的区分是用端口来区分的。 (4)数据偏移:4bit   指出TCP报文段的数据部分距报文段的起始处有多远。单位是32位字 (5)连续的6bit标记位:         URG:数据是否需要紧急发送         ACK:确认字段是否有效。 ACK=1,上面的确认号才有用         PSH:当收到的报文中PSH=1,接收方不等到缓冲区满就把报文交付到上层。         RST:当RST=1,表明TCP连接必须先释放再重新建立         SYN:当SYN=1,表明这是一个连接请求或连接接受         FIN:用来释放一个连接。 (6)窗口:2字节   用来让对方设置发送窗口的大小 (7)紧急指针:16bit   用来指出此报文段中紧急数据站多少字节

二. TCP连接管理

传输连接需要三个过程 (1)连接建立 (2)数据传送 (3)连接释放

连接过程需要解决3个问题: (1)使每一方能够确认对方的存在 (2)允许双方确认一些参数(eg:最大报文段长度,最大发送窗口大小,服务质量等) (3)对传输实体资源进行分配(eg:缓存大小,连接表中的项目等)

TCP3报文连接过程 (1)第一条报文:SYN=1,声明自己是测试连接报文。 (2)第二条报文:SYN=1,ACK=1,并给出自己的seq序号和ack期望对方的序号。表明自己已经接受到了第一条报文。 (3)第三条报文:ACK=1,设置自己的seq序号和希望对方的序号。自己的seq,说明已经接受到了第二条报文 (4)开始传输数据 。 。 。

TCP释放连接 当乙方请求释放连接时,先声明自己已经没有要传输的数据了,FIN=1;然后对方如果还有数据还能发送,直到发送完毕,对方也把FIN设置为1.连接即可释放

三. TCP可靠传输

采用TCP协议连接的双方都要有2个窗口:发送窗口和接收窗口TCP的可靠传输机制:TCP把要传输的报文中的每个字节编上序号。TCP所有确认都是基于序号而不是基于报文TCP两端的4个窗口大小经常处于动态变化。但每时每刻都有 \(Size_{发送窗口} \leq Size_{接收窗口}\)。 此处的窗口大小设置与数据链路层不一样,数据链路层往往是接受窗口小于等于发送窗口,为了尽最大努力交付TCP连接的往返时间RTT也不是固定不变的,因为路由选择的路线不同。这个新RTT是一个估算值。

四. TCP的流量控制和拥塞控制

流量控制:rwnd (1)发送窗口的滑动收到接收窗口的制约: (2)接收方返回的报文中,会带有rwnd=100。表示接受窗口大小为100,此时发送方接收到报文后,就会调整自己的发送窗口为100

拥塞控制:cwnd(congestion window) (1)发送方:根据拥塞窗口cwnd的大小动态改变自己的发送窗口大小 (2)拥塞窗口的大小取决于网络的拥塞程度,在动态的改变。发送方让自己的发送窗口等于拥塞窗口,考虑到接收方的接收能力,发送窗口的大小可能小于拥塞窗口 (3)发送方控制拥塞窗口的原则是:只要网络没拥塞,拥塞窗口就可以再增大一些,以便把更多的报文发送出去。但只要网络出现拥塞,拥塞窗口就减小一些,以减少发送到网络中的分组数。

慢开始原理 (1)在主机刚刚开始发送报文段时,先设置拥塞窗口cwnd=1.即设置一个最大报文段MSS。 (2)随后,每收到一个对新报文段的确认后,拥塞窗口×2,即增加一个MSS的数值 (3)用这种方法逐步增大发送段的拥塞窗口cwnd,可以使分组诸如到网络的速率更加合理(慢开始并不慢) (4)sstresh门限值:         i. 当 cwnd < sstresh 时,使用慢开始算法         ii. 当 cwnd >= sstresh 时,使用拥塞避免算法:每次只增加一个MSS (5)无论在慢开始还是在拥塞阶段,只要发送方出现拥塞(其根据是没有按时收到确认),就把慢开始门限sstresh设置为出现拥塞时的发送方窗口值的一半,然后把拥塞窗口cwnd的值设为1,执行慢开始算法。

快重传,快恢复算法 (1)当发送端连续收到三个重复的确认帧时,就执行“乘法减小”,把慢开始的ssthresh减半,但并不是把拥塞窗口设置为1.因为发送方现在认为网络很可能还没发生拥塞,因此现在不执行慢开始算法,即拥塞窗口cwnd的值设置为慢开始门限sstresh的一半,然后执行拥塞避免算法(“加法增大”),使拥塞窗口缓慢的线性增大。 (2)发送窗口的值为 Min { cwnd , rwnd }

转载于:https://www.cnblogs.com/moonlord/p/5944202.html

最新回复(0)