收藏 分享(赏)

计算机网络第五章课后答案.docx

上传人:weiwoduzun 文档编号:4262223 上传时间:2018-12-19 格式:DOCX 页数:8 大小:22.28KB
下载 相关 举报
计算机网络第五章课后答案.docx_第1页
第1页 / 共8页
计算机网络第五章课后答案.docx_第2页
第2页 / 共8页
计算机网络第五章课后答案.docx_第3页
第3页 / 共8页
计算机网络第五章课后答案.docx_第4页
第4页 / 共8页
计算机网络第五章课后答案.docx_第5页
第5页 / 共8页
点击查看更多>>
资源描述

1、第五章501 试说明运输层在协议栈中的地位和作用,运输层的通信和网络层的通信有什么重要区别?为什么运输层是必不可少的?答:运输层处于面向通信部分的最高层,同时也是用户功能中的最低层,向它上面的应用层提供服务运输层为应用进程之间提供端到端的逻辑通信,但网络层是为主机之间提供逻辑通信(面向主机,承担路由功能,即主机寻址及有效的分组交换) 。各种应用进程之间通信需要“ 可靠或尽力而为” 的两类服务质量,必须由运输层以复用和分用的形式加载到网络层。502 网络层提供数据报或虚电路服务对上面的运输层有何影响?答:网络层提供数据报或虚电路服务不影响上面的运输层的运行机制。但提供不同的服务质量。503 当应

2、用程序使用面向连接的 TCP 和无连接的 IP 时,这种传输是面向连接的还是面向无连接的?答:都是。这要在不同层次来看,在运输层是面向连接的,在网络层则是无连接的。504 试用画图解释运输层的复用。画图说明许多个运输用户复用到一条运输连接上,而这条运输连接有复用到 IP 数据报上。505 试举例说明有些应用程序愿意采用不可靠的 UDP ,而不用采用可靠的 TCP 。答:VOIP:由于语音信息具有一定的冗余度,人耳对 VOIP数据报损失由一定的承受度,但对传输时延的变化较敏感。有差错的 UDP 数据报在接收端被直接抛弃,TCP 数据报出错则会引起重传,可能带来较大的时延扰动。因此 VOIP 宁可

3、采用不可靠的 UDP,而不愿意采用可靠的 TCP 。506 接收方收到有差错的 UDP 用户数据报时应如何处理?答:丢弃507 如果应用程序愿意使用 UDP 来完成可靠的传输,这可能吗?请说明理由答:可能,但应用程序中必须额外提供与 TCP 相同的功能。508 为什么说 UDP 是面向报文的,而 TCP 是面向字节流的?答:发送方 UDP 对应用程序交下来的报文,在添加首部后就向下交付 IP 层。UDP 对应用层交下来的报文,既不合并,也不拆分,而是保留这些报文的边界。接收方 UDP 对 IP 层交上来的 UDP 用户数据报,在去除首部后就原封不动地交付上层的应用进程,一次交付一个完整的报文。

4、发送方 TCP 对应用程序交下来的报文数据块,视为无结构的字节流(无边界约束,课分拆/合并) ,但维持各字节509 端口的作用是什么?为什么端口要划分为三种?答:端口的作用是对 TCP/IP 体系的应用进程进行统一的标志,使运行不同操作系统的计算机的应用进程能够互相通信。熟知端口,数值一般为 01023.标记常规的服务进程;登记端口号,数值为 1024 49151,标记没有熟知端口号的非常规的服务进程;510 试说明运输层中伪首部的作用。答:用于计算运输层数据报校验和。511 某个应用进程使用运输层的用户数据报 UDP,然而继续向下交给 IP 层后,又封装成 IP 数据报。既然都是数据报,可否

5、跳过 UDP 而直接交给 IP 层?哪些功能 UDP 提供了但 IP 没提提供?答:不可跳过 UDP 而直接交给 IP 层IP 数据报 IP 报承担主机寻址,提供报头检错;只能找到目的主机而无法找到目的进程。UDP 提供对应用进程的复用和分用功能,以及提供对数据差分的差错检验。512 一个应用程序用 UDP,到 IP 层把数据报在划分为 4 个数据报片发送出去,结果前两个数据报片丢失,后两个到达目的站。过了一段时间应用程序重传 UDP,而 IP 层仍然划分为4 个数据报片来传送。结果这次前两个到达目的站而后两个丢失。试问:在目的站能否将这两次传输的 4 个数据报片组装成完整的数据报?假定目的站

6、第一次收到的后两个数据报片仍然保存在目的站的缓存中。答:不行重传时,IP 数据报的标识字段会有另一个标识符。仅当标识符相同的 IP 数据报片才能组装成一个 IP 数据报。前两个 IP 数据报片的标识符与后两个 IP 数据报片的标识符不同,因此不能组装成一个 IP 数据报。514 一 UDP 用户数据报的首部十六进制表示是:06 32 0045 00 1C E2 17. 试求源端口、目的端口、用户数据报的总长度、数据部分长度。这个用户数据报是从客户发送给服务器发送给客户?使用 UDP 的这个服务器程序是什么?解:源端口 1586,目的端口 69,UDP 用户数据报总长度 28字节,数据部分长度

7、20 字节。此 UDP 用户数据报是从客户发给服务器(因为目的端口号1023,是熟知端口) 、服务器程序是 TFFTP 。515 使用 TCP 对实时话音数据的传输有没有什么问题?使用 UDP 在传送数据文件时会有什么问题?答:如果语音数据不是实时播放(边接受边播放)就可以使用TCP ,因为 TCP 传输可靠。接收端用 TCP 讲话音数据接受完毕后,可以在以后的任何时间进行播放。但假定是实时传输,则必须使用 UDP。UDP 不保证可靠交付,但 UCP 比 TCP 的开销要小很多。因此只要应用程序接受这样的服务质量就可以使用 UDP。516 在停止等待协议中如果不使用编号是否可行?为什么?答:

8、分组和确认分组都必须进行编号,才能明确哪个分则得到了确认。517 在停止等待协议中,如果收到重复的报文段时不予理睬(即悄悄地丢弃它而其他什么也没做)是否可行?试举出具体的例子说明理由。答:收到重复帧不确认相当于确认丢失518 假定在运输层使用停止等待协议。发送发在发送报文段M0 后再设定的时间内未收到确认,于是重传 M0,但 M0 又迟迟不能到达接收方。不久,发送方收到了迟到的对 M0 的确认,于是发送下一个报文段 M1,不久就收到了对 M1 的确认。接着发送方发送新的报文段 M0,但这个新的 M0 在传送过程中丢失了。正巧,一开始就滞留在网络中的 M0 现在到达接收方。接收方无法分辨 M0

9、是旧的。于是收下 M0,并发送确认。显然,接收方后来收到的 M0 是重复的,协议失败了。试画出类似于图 5-9 所示的双方交换报文段的过程。答:旧的 M0 被当成新的 M0。522 主机 A 向主机 B 发送一个很长的文件,其长度为 L 字节。假定 TCP 使用的 MSS 有 1460 字节。(1)在 TCP 的序号不重复使用的条件下,L 的最大值是多少?(2)假定使用上面计算出文件长度,而运输层、网络层和数据链路层所使用的首部开销共 66 字节,链路的数据率为10Mb/s,试求这个文件所需的最短发送时间。解 :(1)L_max 的最大值是 232=4GB,G=230.(2) 满载分片数 Q=

10、L_max/MSS取整=2941758 发送的总报文数N=Q*(MSS+66)+ ( L_max - Q*MSS )+66=4489122708+682=4489123390总字节数是 N=4489123390 字节,发送 4489123390 字节需时间为:N*8/(10*106)=3591.3 秒,即 59.85 分,约 1 小时。523 主机 A 向主机 B 连续发送了两个 TCP 报文段,其序号分别为 70 和 100。试问:(1)第一个报文段携带了多少个字节的数据?(2)主机 B 收到第一个报文段后发回的确认中的确认号应当是多少?(3)如果主机 B 收到第二个报文段后发回的确认中的确

11、认号是 180,试问 A 发送的第二个报文段中的数据有多少字节?(4)如果 A 发送的第一个报文段丢失了,但第二个报文段到达了 B。B 在第二个报文段到达后向 A 发送确认。试问这个确认号应为多少?解 :(1)第一个报文段的数据序号是 70 到 99,共 30 字节的数据。(2)确认号应为 100.(3)80 字节。(4)70525 为什么在 TCP 首部中要把 TCP 端口号放入最开始的 4个字节?答:在 ICMP 的差错报文中要包含 IP 首部后面的 8 个字节的内容,而这里面有 TCP 首部中的源端口和目的端口。当 TCP收到 ICMP 差错报文时需要用这两个端口来确定是哪条连接出了差错

12、。526 为什么在 TCP 首部中有一个首部长度字段,而 UDP 的首部中就没有这个这个字段?答:TCP 首部除固定长度部分外,还有选项,因此 TCP 首部长度是可变的。UDP 首部长度是固定的。527 一个 TCP 报文段的数据部分最多为多少个字节?为什么?如果用户要传送的数据的字节长度超过 TCP 报文字段中的序号字段可能编出的最大序号,问还能否用 TCP 来传送?答:65495 字节,此数据部分加上 TCP 首部的 20 字节,再加上 IP 首部的 20 字节,正好是 IP 数据报的最大长度 65535.(当然,若 IP 首部包含了选择,则 IP 首部长度超过 20 字节,这时 TCP

13、报文段的数据部分的长度将小于 65495 字节。 )数据的字节长度超过 TCP 报文段中的序号字段可能编出的最大序号,通过循环使用序号,仍能用 TCP 来传送。528 主机 A 向主机 B 发送 TCP 报文段,首部中的源端口是m 而目的端口是 n。当 B 向 A 发送回信时,其 TCP 报文段的首部中源端口和目的端口分别是什么?答:分别是 n 和 m。529 在使用 TCP 传送数据时,如果有一个确认报文段丢失了,也不一定会引起与该确认报文段对应的数据的重传。试说明理由。答:还未重传就收到了对更高序号的确认。530 设 TCP 使用的最大窗口为 65535 字节,而传输信道不产生差错,带宽也

14、不受限制。若报文段的平均往返时延为20ms,问所能得到的最大吞吐量是多少?答:在发送时延可忽略的情况下,最大数据率= 最大窗口*8/平均往返时间=26.2Mb/s。531 通信信道带宽为 1Gb s ,端到端时延为 10ms。TCP 的发送窗口为 65535 字节。试问:可能达到的最大吞吐量是多少?信道的利用率是多少?答:L=655368+408=524600C=109b/sL/C=0.0005246sTd=1010-3s0.02104864Throughput=L/(L/C+2Td)=524600/0.0205246=25.5Mb/sEfficiency=(L/C)/(L/C+2D)=0.0

15、255最大吞吐量为 25.5Mb/s 。信道利用率为 25.5/1000=2.55%535 试计算一个包括 5 段链路的运输连接的单程端到端时延。5 段链路程中有 2 段是卫星链路,有 3 段是广域网链路。每条卫星链路又由上行链路和下行链路两部分组成。可以取这两部分的传播时延之和为 250ms 。每一个广域网的范围为1500km,其传播时延可按 150000kms 来计算。各数据链路速率为 48kbs ,帧长为 960 位。答:5 段链路的传播时延=250*2+ (1500/150000 )*3*1000=530ms5 段链路的发送时延=960/(48*1000)*5*1000=100ms所以

16、 5 段链路单程端到端时延=530+100=630ms536 重复 5-35 题,但假定其中的一个陆地上的广域网的传输时延为 150ms 。答:760ms545 解释为什么突然释放运输连接就可能会丢失用户数据,而使用 TCP 的连接释放方法就可保证不丢失数据。答:当主机 1 和主机 2 之间连接建立后,主机 1 发送了一个TCP 数据段并正确抵达主机 2,接着主机 1 发送另一个 TCP数据段,这次很不幸,主机 2 在收到第二个 TCP 数据段之前发出了释放连接请求,如果就这样突然释放连接,显然主机 1发送的第二个 TCP 报文段会丢失。而使用 TCP 的连接释放方法,主机 2 发出了释放连接

17、的请求,那么即使收到主机 1 的确认后,只会释放主机 2 到主机 1 方向的连接,即主机 2 不再向主机 1 发送数据,而仍然可接受主机1 发来的数据,所以可保证不丢失数据。546 试用具体例子说明为什么在运输连接建立时要使用三次握手。说明如不这样做可能会出现什么情况。答:3 次握手完成两个重要的功能,既要双方做好发送数据的准备工作(双方都知道彼此已准备好) ,也要允许双方就初始序列号进行协商,这个序列号在握手过程中被发送和确认。假定 B 给 A 发送一个连接请求分组,A 收到了这个分组,并发送了确认应答分组。按照两次握手的协定,A 认为连接已经成功地建立了,可以开始发送数据分组。可是,B 在

18、 A 的应答分组在传输中被丢失的情况下,将不知道 A 是否已准备好,不知道 A 建议什么样的序列号,B 甚至怀疑 A 是否收到自己的连接请求分组,在这种情况下,B 认为连接还未建立成功,将忽略 A 发来的任何数据分组,只等待连接确认应答分组。而 A 发出的分组超时后,重复发送同样的分组。这样就形成了死锁。部分题目还有另外的答案,仅供参考:5-01 试说明运输层在协议栈中的地位和作用。运输层的通信和网络层的通信有什么重要的区别?为什么运输层是必不可少的?运输层是七层模型中最重要最关键的一层,是唯一负责总体数据传输和控制的一层。运输层要达到两个主要目的:第一提供可靠的端到端的通信;第二,向会话层提

19、供独立于网络的运输服务。在讨论为实现这两个目标所应具有的功能之前,先考察一下运输层所处的地位。首先,运输层之上的会话层、表示层及应用层均不包含任何数据传输的功能,而网络层又不一定需要保证发送站的数据可靠地送至目的站;其次会话层不必考虑实际网络的结构、属性、连接方式等实现的细节。根据运输层在七层模型中的目的和地位,它的主要功能是对一个进行的对话或连接提供可靠的传输服务;在通向网络的单一物理连接上实现该连接的利用复用;在单一连接上进行端到端的序号及流量控制;进行端到端的差错控制及恢复;提供运输层的其它服务等。运输层反映并扩展了网络层子系统的服务功能,并通过运输层地址提供给高层用户传输数据的通信端口

20、,使系统间高层资源的共享不必考虑数据通信方面的问题。运输层的最终目标是为用户提供有效、可靠和价格合理的服务。图. 给出了运输层与网络层、运输服务用户三者之间的关系。在一个系统中,运输实体通过网络服务与其它运输实体通信,向运输层用户(可以是应用进程,也可以是会话层协议)提供运输服务。运输层的服务包括的内容有:服务的类型、服务的等级、数据运输、用户接口、连接管理、快速数据运输、状态报告、安全保密等。可以把运输层看做公交车的调度,而网络层只是负责运输乘客而已5.3. 当应用程序使用面向连接的 TCP 和无连接的 IP 时,这种传输是面向连接的还是无连接的?TCP/IP 协议在网络层是无连接的(数据包

21、只管往网上发,如何传输和到达以及是否到达由网络设备来管理) 。而“ 端口“ ,是传输层的内容,是面向连接的。协议里面低于 1024 的端口都有确切的定义,它们对应着因特网上常见的一些服务。5.5. 试举例说明有些应用程序愿意采用不可的 UDP ,而不愿意采用可靠的 TCP 。UDP 主要用于那些面向查询- 应答的服务,例如 NFS 。相对于 FTP 或 Telnet,这些服务需要交换的信息量较小。使用 UDP的服务包括 NTP(网落时间协议)和 DNS(DNS 也使用 TCP ) 。UDP 是无连接的,即发送数据之前不需要建立连接。UDP 使用尽最大努力交付,即不保证可靠交付,同时也不使用拥塞

22、控制。UDP 是面向报文的。UDP 没有拥塞控制,很适合多媒体通信的要求。 UDP 支持一对一、一对多、多对一和多对多的交互通信。UDP 的首部开销小,只有 8 个字节。UDP 在数据传送之前不需要先建立连接。原地主机的运输层在收到 UDP 报文之后,不需要给出任何确认。虽然 UDP不提供可靠的交付,但在某种情况下 UDP 是一种最有效的工作方式。TCP 则提供面向连接的服务。在传送数据之前必须建立连接,数据传送结束之后要释放连接。TCP 不提供广播或多播服务。由于 TCP 要提供可靠的、面向连接的运输服务,因此不可避免的增加了许多的开销,如确认、流量控制、计时器以及连接管理等。这部仅使协议数

23、据单元的手不增大了很多、还要占用许多的处理及资源。5.9. 端口的作用是什么?为什么端口号要划分为三种?一台拥有 IP 地址的主机可以提供许多服 务,比如 web 服务ftp 服务和 smtp 服务等,这些服务完全可以通过 1 个 IP 地址来实现。那么,主机是怎样区分不同的网络服务呢?显然不能只靠 IP 地址,因为 IP 地址与网络服务的关系是一对多的关系。实际上是通过“IP 地址+端口号”来区分不同的服务的。因此客户在发起通信请求时,必须先知道对方服务器的 IP 地址和端口号因此可将运输层的端口号分为下面几类。(1)公认端口(Well Known Ports): 从 0 到 1023,它们

24、紧密绑定(bindin g )于一些服务。通常这些端口的通讯明确表明了某种服务的协议。例如:80 端口实际上总是 HTTP 通讯。(2)注册端口(Registered Ports): 从 1024 到 49151。它们松散地绑定于一些服务。也就是说有许多服务绑定于这些端口,这些端口同样用于许多其它目的。许多系统处理动态端口从1024 左右开始。(3)动态和/或私有端口(Dynamicand / or Private Ports): 从49152 到 65535。理论上,不应为服务分配这些端口。实际上,机器通常从 1024 起分配动态端口。5.23 主机 A 向主机 B 连续发送了两个 TCP

25、报文段,其序号分别为 70 和 100. 试问:(1). 第一个报文段携带了多少字节的数据?数据为从 70-99 ,100-70=30 。(2). 主机 B 收到第一个报文段后发回的确认号应当是多少?发回受到的确认号为 100(3). 如果 B 收到第二个报文段后发回的确认号是 180,试问 A发送的第二个报文段的数据有多少字节?确认号为 180,则数据为 180-100=80.(4). 如果 A 发送的第一个报文段丢失了,但第二个到达 B,B在第二个报文段到达后向 A 发送了确认。试问这个确认号应为多少?由于没有收到第一个报文段,则确认号为 70.5.46. 使用具体的例子说明为什么在运输连

26、接建立时使用三次握手。说明不这样做会产生什么后果?答: 3 次握手完成两个重要的功能,既要双方做好发送数据的准备工作(双方都知道彼此已准备好) ,也要允许双方就初始序列号进行协商,这个序列号在握手过程中被发送和确认。现在把三次握手改成仅需要两次握手,死锁是可能发生的。作为例子,考虑计算机 A 和 B 之间的通信,假定 B 给 A 发送一个连接请求分组,A 收到了这个分组,并发送了确认应答分组。按照两次握手的协定,A 认为连接已经成功地建立了,可以开始发送数据分组。可是,B 在 A 的应答分组在传输中被丢失的情况下,将不知道 A 是否已准备好,不知道 A 建议什么样的序列号,B 甚至怀疑 A 是否收到自己的连接请求分组。在这种情况下,B 认为连接还未建立成功,将忽略 A 发来的任何数据分组,只等待连接确认应答分组。而 A 在发出的分组超时后,重复发送同样的分组。这样就形成了死锁。

展开阅读全文
相关资源
猜你喜欢
相关搜索

当前位置:首页 > 网络科技 > 计算机原理

本站链接:文库   一言   我酷   合作


客服QQ:2549714901微博号:道客多多官方知乎号:道客多多

经营许可证编号: 粤ICP备2021046453号世界地图

道客多多©版权所有2020-2025营业执照举报