Ch62ed传输层

上传人:沈*** 文档编号:181587224 上传时间:2023-01-14 格式:PPT 页数:87 大小:1.34MB
收藏 版权申诉 举报 下载
Ch62ed传输层_第1页
第1页 / 共87页
Ch62ed传输层_第2页
第2页 / 共87页
Ch62ed传输层_第3页
第3页 / 共87页
资源描述:

《Ch62ed传输层》由会员分享,可在线阅读,更多相关《Ch62ed传输层(87页珍藏版)》请在装配图网上搜索。

1、2021/7/11第6章 传输层 2021/7/12本章内容6.1 传输层的基本概念6.2 因特网上的用户数据报协议6.3 因特网上的传输控制协议6.4 用于多媒体传输控制的实时传输/传输控制 协议2021/7/13l网络层已经保证了寻址到目的主机,那么传输层的任务是什么?l传输层的端到端通信是什么含义,是指源端点到目的端点之间的通信,还是指端点应用进程之间的通信?l传输层向上层提供哪两种不同的服务?2021/7/146.1 传输层的基本概念l面向连接和无连接服务l因特网上的端到端通信l端口和套接字的概念l传输层的多路复用与多路分解2021/7/156.1.1 面向连接和无连接服务l计算机网络

2、通常提供两种类型的服务面向连接服务(connection-oriented service)无连接服务(connectionless service)2021/7/161.面向连接服务l数据传输之前发送方必须与数据接收方建立连接,然后才可以进行数据交换。数据传输结束后终止连接,以释放系统资源。l包括连接建立,数据传输和连接释放三个阶段。l按序传送,可靠性高。适合于在一定期间内向同一数据接收方发送大量报文的情况。l传输层面向连接的协议:TCP。2021/7/17l进行数据传输前发送方不必与数据接收方建立连接,可直接向接收方发送数据。l无连接服务的特点:使用方便灵活开销小通信迅速可靠性低2021/

3、7/18l端到端的通信是指端点应用程序进程之间的通信。l传输层协议的主要任务是保障端点应用程序进程之间的通信,因此传输层协议也被称为端到端协议(end-to-end protocol)。2021/7/19端到端应用程序进程之间的通信2021/7/1106.1.3 端口和套接字的概念l传输层通过端口控制机制实现端点应用程序进程之间的通信。l传输层的端口并非是物理意义上的端口,而是逻辑意义上的端口。l端口通过端口号来标记,范围为065535。2021/7/111传输层的端口号分类1)熟知端口(well known ports)该类端口号范围为01023,它们通常绑定于一些众所周知的服务,这些端口由

4、系统调用。2021/7/112部分常用的熟知端口号端口号端口号应用协议应用协议 21/20文件传输协议 23远程终端协议 25简单邮件传输协议 53DNS 67/68动态主机配置协议 80超文本传输协议 161简单网络管理协议2021/7/113 2)注册端口(registered ports)该类端口号范围为102449151。它们通常用于众所周知服务之外的不常用的服务。3)动态和/或私有端口(dynamic and/or private ports)该类端口号范围为4915265535,该类端口不可以被正式地注册占用。2021/7/114套接字(socket)l为了区分不同的网络应用服务,

5、就必须把主机的IP地址和端口号进行绑定后使用。l主机IP地址和端口号的绑定组成了套接字(socket)。2021/7/115主机IP地址、端口号和套接字的对应关系2021/7/116端到端多应用程序进程之间的通信2021/7/117l传输层端到端通信提供对应用报文的多路复用和多路分解功能(在传输层上)。l传输层的多路复用:多个应用程序进程使用同一个传输层协议发送数据报。l传输层的多路分解:传输层协议将接收到的报文分发给不同的应用程序进程。l多路复用和多路分解功能通过传输层协议的端口机制实现。2021/7/118传输层的多路复用和多路分解2021/7/119lUDP概述lUDP数据报结构lUDP

6、校验和2021/7/1206.2.1 UDP概述l用户数据报协议(User Datagram Protocol,UDP)是向上层提供数据报服务的简单的无连接传输层协议。l它在网络层IP的基础上,增加了端口机制和简单的校验机制。lUDP为因特网应用提供最基本和最简便的通信服务。lRFC 768对UDP做出了明确定义和规范。2021/7/121采用UDP的因特网应用应用应用应用层协议应用层协议运输层协议运输层协议远程文件服务器 NFSUDP网络管理 SNMPUDPIP电话专用UDP流式多媒体专用UDP域名服务DNSUDP2021/7/1226.2.1 UDPlUDP具有如下特点:无连接尽力而为的传

7、输首部开销小无拥塞控制2021/7/1236.2.2 UDP数据报 lUDP数据报由两部分组成:UDP数据报首部和UDP数据报数据部分。2021/7/124l源端口是可选字段,长度为2个字节。被使用时,它指向源应用程序进程端口;若源端口不被使用,可将该字段填充为0。l目的端口长度为2个字节,只有在拥有特定的目的网络地址时才有意义。2021/7/125l报文长度字段:长度为2个字节,报文总长度,是UDP数据报首部和UDP数据报数据部分的总的字节数,其长度单位为字节。l校验和:可选字段,长度为2个字节。主要用来检测UDP报文是否出错。当该字段不被使用时,可将其值设置为0。2021/7/126UDP

8、伪首部l计算校验和时,需要对UDP首部进行扩充。l扩充部分称为UDP伪首部,长度为12字节。l伪首部信息来源于IP首部部分字段:源IP地址,目的IP地地址0填充字段(使扩充部分长度为4B的整数倍)所用协议(UDP为17)UDP长度l伪首部只在计算校验和时使用。2021/7/127UDP数据报伪首部结构2021/7/1286.2.3 UDP校验和lUDP通常采用检验和法对数据报进行检测。l源端口采用二进制反码求和运算计算校验和先将校验和字段清零每两字节为一个操作数相加运算中最高位出现进位时回卷与结果相加最后结果取反成为校验和字段的值l目的端口对收到的数据报进行同样的运算,求和结果为全1时报文无差

9、错。2021/7/129121.195.169.133121.195.170.25全全0111710926911全全0数据数据数据数据数据数据全全012字节字节伪首部伪首部8字节字节UDP首部首部3字节字节数据数据01111001 11000011 121.19510101001 10000101 169.13301111001 11000011 121.19510101010 00011001 170.2500000000 00010001 0和和1700000000 00001011 1100000100 01000100 109200000000 00001011 1100000000

10、00000000 0(校验和校验和)00110101 01000111 数据数据01010001 00000000 数据和数据和011010010 00011011 求和得出的结果求和得出的结果00101101 11100100 校验和校验和求反码求反码填充填充计算UDP校验和示例2021/7/130RUDPlUDP提供不可靠的数据报服务l可以考虑通过在应用服务中自行增加报文序号、报文确认、报文重传、连接控制、流量控制和拥塞控制等可靠性机制,实现使用UDP进行可靠的端到端的通信。l这种改进的UDP协议通常称为可靠的UDP(Reliable UDP,RUDP)。2021/7/1316.3 因特网

11、上的传输控制协议lTCP概述lTCP报文段结构lTCP序号与确认lTCP重传机制lTCP连接管理lTCP流量控制lTCP拥塞控制2021/7/1326.3.1 TCP概述l传输控制协议(Transmission Control Protocol,TCP)是面向连接、面向字节流的可靠的传输层协议。lTCP采用报文序号、报文确认、报文重传、连接控制、流量控制和拥塞控制等一系列可靠性机制,为因特网应用提供可靠的通信服务。lIETF RFC 793、RFC 1323和RFC 2581等对TCP做出了明确的定义和规范。2021/7/133采用TCP的因特网应用应用应用应用层协议应用层协议运输层协议运输层

12、协议电子邮件SMTPTCP远程终端访问TelnetTCP万维网HTTPTCP文件传输FTPTCP2021/7/134lTCP具有如下特点:面向连接面向字节流全双工通信提供可靠的传输服务2021/7/1356.3.2 TCP报文段结构lTCP是面向字节流的数据通信协议,我们将源端口和目的端口之间传输的数据单元称为TCP报文段。lTCP报文段的组成:TCP报文段首部TCP报文段数据部分2021/7/136TCP报文段结构2021/7/137l源端口和目的端口:分别用来标识发送和接收TCP报文段的应用程序进程,与IP数据报中的源IP地址和目的IP地址组成插口,以唯一确定因特网中的TCP连接双方。源端

13、口和目的端口的长度都为2个字节。l序号字段:标识TCP报文段数据部分第一个字节在源端口发送字节流中的位置,长度为4个字节。l确认号字段:标识目的端口希望接收到的下一个TCP报文段数据部分第一个字节的序号,其长度为4个字节。2021/7/138l首都长度字段:标识TCP报文段首部的长度,长度为4个比特位。首都长度字段的度量单位是4字节,TCP报文段首部的最大长度为60字节。l保留字段:为今后应用保留,长度为6个比特位,通常设置为0。l标志位字段:包含有6个标志位,从左到右分别为URG、ACK、PSH、RST、SYN和FIN,它们用来标识不同类型的TCP报文段。长度为6个比特位。2021/7/13

14、9标志位字段的含义及使用说明名称名称含义含义使用说明使用说明URG设URG=1时,表明报文段中有紧急数据,这时紧急指针字段有效。紧急数据插在报文段数据的前面,可以先被处理。ACK设ACK=1时,表明确认号字段有效用于设置确认号字段PSH设PSH=1时,表明请求推操作有效发送方设置PSH=1,是让目的端口尽快将接收到的TCP报文段交付(推送)给应用层,而不必在缓冲中排队RST设RST=1时,表明连接复位操作有效用于设置连接复位,当TCP连接出现错误时,需要断开连接,再重新建立连接SYN设SYN=1时,ACK=0时,表示请求建立TCP连接;当SYN=1,ACK=1时,表示响应建立TCP连接当TCP

15、建立连接时,用于设置同步序号,通常与ACK标志位配合使用FIN设FIN=1时,表明源端口的字节流发送完毕,并请求断开连接用于连接释放2021/7/140l窗口字段:2个字节,进行流量控制。接收方通知发送方自己目前能够接收数据量(由缓冲空间限制),发送方据此设置发送窗口。l校验和字段:TCP报文段的差错检测,长度为2个字节。TCP校验和计算方法与UDP校验和计算方法相同。l紧急指针字段与标志位字段中的URG标志位配合使用,长度为2个字节。l选项:为TCP提供扩展功能l填充字段:当选项部分长度不是4个字节的整数倍时,需要进行填充。2021/7/1416.3.3 TCP序号与确认l在TCP传输的字节

16、流中,TCP为每个字节分配一个序号,序号为32位无符号数,在区间为0232-1中循环使用。l在TCP连接建立时,源端口与目的端口需要商定一个初始序号,以后发送的报文段中序号的设置是初始序号的延续。2021/7/142TCP报文段序号分配示例2021/7/143l在TCP报文段传输过程中,由于网络拥塞,可能会出现报文段丢失的情况,这就需要目的端口对所接收到的正确的报文段进行确认,以便通知源端口所发送的报文段的目前状态。lTCP支持选择确认、累积确认和捎带确认。2021/7/1446.3.4 TCP重传机制l若TCP报文段在传输过程中丢失或产生差错,将采用重传机制重传此类报文段。l缓存缓存-定时定

17、时-超时重传超时重传:源端口在发送一个TCP报文段时,首先将复制一个副本存放在缓冲区内,并启动计时器;如果在规定的时间内没有收到来自目的端口的确认信息,则判定该报文段丢失或产生差错,并重传该报文段副本。2021/7/145l计时器超时时间(TimeOut)的设置:取决于TCP报文段传输的往返时间(Round Trip Time,RTT),即从源端口到达目的端口以及源端口收到目的端口的确认信息的所经历的总时间。l由于因特网环境的不确定性,RTT是变化的。lTCP采用了自适应重传算法以适应网络的不确定性。2021/7/146l自适应重传算法的基本思想:TCP监视每一个连接的性能,根据相应连接RTT

18、的变化随时调整TimeOut的设置,以适应因特网环境的变化。l计算平滑的RTTRTT=*Old_RTT+(1-)*New_SampleRTT(01)(建议值为2)2021/7/147发送报文段发送报文段重传该报文段重传该报文段收到收到ACK确认确认源端口源端口A目的端口目的端口BRTT2RTT1无法确认该无法确认该ACK信息是针对第一信息是针对第一次发送的报文段还是重传报文段次发送的报文段还是重传报文段TCP确认的二义性2021/7/148l问题:发生重传时新的RTT不可知。lKarn算法:不采用发生重传时测得的RTT来重新计算往返时间估计值。l新问题:网络延时增大没有及时反映在超时值上,会导

19、致更多的重传发生。l对Karn算法的修正:发生重传时,增加超时值:New_TimeOut=*TimeOut(1)(取值通常为2)2021/7/1496.3.5 TCP连接管理lTCP是一个面向连接的协议,通信双方不论哪一方发送报文段,都必须首先建立一条连接,并在双方数据通信结束后关闭连接。2021/7/1501.建立连接lTCP使用三次握手建立连接。l在建立连接过程中,请求发起连接建立的应用进程被称为客户,等待建立连接的应用进程被称为服务器。l为了建立连接,服务器执行被动打开命令等待连接请求的到达;客户则执行主动打开命令,并指明它想要连接到的服务器的IP地址和端口号,等待服务器的响应。2021

20、/7/151三次握手建立TCP连接2021/7/1522.关闭连接lTCP通信是全双工通信,通信双方中的任何一方在数据传输结束后,都可以向对方发起关闭连接的请求,以结束一个方向的连接。2021/7/153客户客户A服务器服务器B发送发送FIN报文段报文段SEQ=x接收接收FIN报文段报文段发送发送ACK报文段报文段SEQ=y,ACK=x+1接收接收ACK报文段报文段发送发送FIN+ACK报文段报文段SEQ=y,ACK=x+1接收接收FIN+ACK报文段报文段发送发送ACK报文段报文段SEQ=x+1,ACK=y+1接收接收ACK报文段报文段关闭一个TCP连接2021/7/1543.连接状态管理模

21、型lTCP采用有限状态机的连接状态管理模型,该模型能够解释TCP连接中各种可能的状态以及状态下一步可能发生的转换。lTCP有限状态机中共包含有11种状态,每个TCP连接都从CLOSED状态开始。2021/7/1552021/7/156发起连接请求方建立和关闭一个TCP连接状态转换过程2021/7/157被请求方建立和关闭一个TCP连接状态转换过程2021/7/1586.3.6 TCP流量控制l由于TCP通信双方缓冲空间分配以及数据处理速度的不同,可能会造成接收方数据溢出的情况,这就需要一种控制机制能够协调通信双方的数据流量。lTCP 使用滑动窗口机制解决上述问题。l每个TCP连接维持两个窗口,

22、即发送窗口和接收窗口,窗口大小的单位是字节。l接收的报文段可能乱序到达。2021/7/159TCP发送窗口TCP接收窗口2021/7/160l在TCP流量控制过程中,发送窗口的大小随着接收方发布的窗口通告值进行调整。l窗口通告值增大时,发送方扩大发送窗口的大小,以便发送更多的数据。l窗口通告值减小时,发送方缩小发送窗口的大小,以便接收方能够来得及接收数据。l窗口通告值减小至零时,发送方将停止发送数据,直到窗口通告值重新调整为大于零的数值。2021/7/161发送方发送方A接收方接收方BSEQ=1ACK=1001SEQ=1001ACK=2001SEQ=2001ACK=3001 WIN=2000S

23、EQ=3001ACK=4001SEQ=4001ACK=5001 WIN=0ACK=5001 WIN=1000SEQ=5001调整窗口通告值为调整窗口通告值为2000字节字节TCP流量控制2021/7/1626.3.7 TCP拥塞控制l拥塞(congestion)是指因特网中的数据报过多,超过了中间结点的最大容量,导致网络性能急速下降的现象。l拥塞控制(congestion control)算法主要用于避免拥塞现象发生。lTCP通常综合采用慢开始、拥塞避免、快速重传和快速恢复等拥塞控制算法。lTCP流量控制只考虑接收方的接收能力。2021/7/163拥塞发生过程无拥塞时:吞吐量与网络负载呈线性增

24、长的关系;轻度拥塞:吞吐量随着网络负载的增长而缓慢增长;严重拥塞:吞吐量随着网络负载的增长而急剧降低直至死锁。2021/7/164拥塞窗口l接收窗口rwnd(receiver window):流量控制中接收方的通告值,反映接收方的接受能力,不能体现中间结点的处理能力。l拥塞窗口 cwnd(Congestion window):由发送方根据网络的情况设置,表示发送方允许发送的最大报文段。2021/7/1651.慢开始和拥塞避免l慢开始算法要点:建立连接后,拥塞窗口的初始值设置为1(1个报文段)。发送方取rwnd和cwnd中的较小值作为当前发送窗口值进行数据报发送。每收到一个新的报文段的确认,将拥

25、塞窗口的大小增加一个报文段,cwnd以指数方式快速地增长。每收到1个确认,cwnd值就增加1(cwnd 从1到2)收到2个确认,cwnd值就增加2(cwnd 从2到4)2021/7/166发送方发送方接收方接收方发送报文段发送报文段1发送报文段发送报文段2-3发送报文段发送报文段4-7确认报文段确认报文段1确认报文段确认报文段2-3确认报文段确认报文段4-7慢开始算法cwnd=2 cwnd=42021/7/167慢开始阈值l慢开始算法中的拥塞窗口cwnd会以指数方式快速增长。l为避免cwnd过快增长引起网络拥塞,设置慢开始阈值慢开始阈值(ssthresh)。cwnd ssthresh时采用慢开

26、始算法;cwnd ssthresh时采用拥塞避免算法,减慢窗口增长速度。2021/7/168拥塞避免算法当cwnd ssthresh后,启用拥塞避免算法:l每经过一个往返时延RTT,只有当发送方收到对所有报文段的确认后,才将拥塞窗口的大小增加一个报文段。l加法增加(Additive Increase)策略,cwnd按照线性方式缓慢增长,与慢开始算法相比,其增长速度放慢,直到网络出现拥塞。2021/7/169cwnd=ssthresh设设ssthresh=4cwnd=5cwnd=6慢开始算法拥塞避免算法2021/7/170乘法减小策略若有报文段丢失,则判定网络发生拥塞,此时不论是处于慢开始阶段还

27、是拥塞避免阶段,发送方将采用乘法减小(Multiplicative Decrease)的策略:l慢开始阈值ssthresh减为当前cwnd的一半(但不能小于2)。lcwnd重新设为1,启动慢开始算法。lcwnd增长到新的慢开始阈值ssthresh大小时,进入拥塞避免阶段。2021/7/171慢开始和拥塞避免算法示例2021/7/1722.快速重传算法l接收方收到乱序到达的TCP报文段后,立即发送确认报文段,通告期待接收的报文段最小序号。l若发送方连续收到三个重复的确认报文段,认定该报文段丢失。无论计时器时间是否结束,立即重传该报文段。2021/7/173 快速重传算法示意图2021/7/174

28、 快速恢复算法l 发送方连续收到三个重复的确认报文段,启动拥塞避免算法:将慢开始阈值ssthresh减半将拥塞窗口cwnd的大小调整为更新后的ssthresh的值启动拥塞避免算法,之后拥塞窗口cwnd的值按照线性方式增长l不启动慢开始算法的原因:只有一个报文段丢失,其它报文段正确接收,说明当前网络并没有发生严重的拥塞。2021/7/1756.4 用于多媒体传输的实时传输/传输控制协议lRTP:用于音视频等多媒体数据流的传输协议。lRTCP:在RTP会话期间,为RTP提供带外控制。lRTP/RTCP应用在UDP协议之上。lIETF RFC 3550对RTP/RTCP做出了明确的定义和规范。202

29、1/7/176 RTP报文格式2021/7/177lVER:2位,协议的版本号,当前版本号为2。lP:位,填充位,如果有效载荷后面需要填充,则该位置位。lX:1位,扩展位,如果该位设置,则在固定首部后跟随有一个扩展首部。lCC:4位,参与源计数,指出在固定首部后的参与源的数目。lM:1位,标记位,含义取决于具体的应用。lPT:7位,定义有效载荷类型。2021/7/178l序号:16位,RTP报文序号,接收端可通过序号来检查报文段的丢失情况,并可针对乱序的报文段进行重新按序排列。l时间戳:长度为32位,给出RTP报文段中第一个字节的采样时间。可用于接收端对时延抖动的消除和对具体应用的同步。202

30、1/7/179l同步源标识符(Synchronization SouRCe identifier,SSRC):32位,标识数据流的源,随每个数据流的开始时随机产生,每一个数据流都有一个唯一的同步源标识符。l参与源标识符(Contributing SouRCe identifier,CSRC):参与源个数不定,但最多不超过15个每个为32位。该字段由混合器插入,标识混合器中不同的数据流,混合器将多个数据流合并起来,形成一个数据流进行传输。2021/7/180封装到UDP中的RTP报文段2021/7/181RTCPlRTCP应用在UDP协议之上,其主要功能是提供RTP服务质量的反馈,为RTP提供带

31、外控制。l在RTP会话期间,同一个RTP会话的参与者采用IP多播的方式定期发送RTCP报文。lIETF RFC 3550对RTCP做出了明确的定义和规范。2021/7/182RTCP五种基本报文类型类型类型意义意义200发送端报告(发送端报告(SR)201接收端报告(接收端报告(RR)202源描述(源描述(SDES)203结束(结束(BYE)204特定应用(特定应用(APP)2021/7/183lSR:针对所发送的每个RTP数据流提供信息,主要包含:RTP流的SSRC流中最新分组的RTP时间戳绝对时钟(NTP)时间戳,用来同步一个RTP会话中的不同媒体流(如视频流和音频流)。也可以根据发送和接

32、收双方的NTP时间戳计算往返时延。流所发送的分组数和字节数等。2021/7/184lRR:接收端定期向发送端报告,针对每个RTP媒体数据流提供报告信息,以便发送端了解接收状况,并根据实际情况调整发送策略。l主要包含:RTP流的SSRC流的分组丢失数、丢失率、时延抖动流中最新收到的RTP分组的序号等。2021/7/185l源描述(SDES):于描述RTP流的发送端(源),基本信息包括:用于标识发送方的规范名称(可按照某种格式自动生成,如doe192.0.2.89等)创建该RTP流的应用程序或工具的名称用户名、用户的电子邮件地址、电话号码等信息。l结束报文(BYE)报文:表示会话成员退出,该数据源关闭。l特定应用(APP)报文:由应用程序自己定义。2021/7/186课后思考题l在因特网中,用什么来唯一地唯一地标识特定的网络应用程序进程?l从目标和手段两方面分析:流量控制和拥塞控制有什么不同?若有不当之处,请指正,谢谢!若有不当之处,请指正,谢谢!

展开阅读全文
温馨提示:
1: 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
2: 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
3.本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
5. 装配图网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
关于我们 - 网站声明 - 网站地图 - 资源地图 - 友情链接 - 网站客服 - 联系我们

copyright@ 2023-2025  zhuangpeitu.com 装配图网版权所有   联系电话:18123376007

备案号:ICP2024067431-1 川公网安备51140202000466号


本站为文档C2C交易模式,即用户上传的文档直接被用户下载,本站只是中间服务平台,本站所有文档下载所得的收益归上传人(含作者)所有。装配图网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。若文档所含内容侵犯了您的版权或隐私,请立即通知装配图网,我们立即给予删除!