【2017年整理】计算机网络期末复习题
计算机网络期末复习题
2-5
运行在一台主机上的一个进程使用什么信息来标示运行在另一台主机上的进程。
2-6
假定你想尽快地处理从远程客户机到服务器的事务,应使用UDP还是TCP,为什么?
2-10
握手协议的作用是什么?
2-11
为什么HTTP、FTP、SMTP、POP3都运行在TCP而不是UDP之上?
3-6
当应用程序运行在UDP上时,该应用程序是否能够得到可靠数据传输?如果能,如何实现?
3-9
在rdt协议中,为什么需要引入序号
3-10
在rdt协议中。为什么需要引入定时器
3-14
是非判断题:
主机A通过一条TCP连接主机B发送一个大文件。假设主机B没有数据发往主机A。因为主机B不能随数据捎带确认信息,所以主机B将不向主机A发送确认。
在连接的整个过程中,TCP的RcvWindow的长度不会变化。
假设主机A通过一条TCP连接向主机主机B发送一个大文件。主机A发送的未被确认的字节数不会超过接收缓存的大小
假设主机A通过一条TCP连接向主机B发送一个大文件。如果对于这次连接的TimeoutInterval的当前值必定>=1S。
TCP报文段在它的首部中有一个RcvWindow字段。
假定在一条TCP连接中最后的SampleRTT等于1s,那么对于这一连接的TimeoutInterval的当前值必定>=1s.
假定主机A通过一条TCP连接向主机B连续发送一个序号为38的4字节报文段。这个报文段的确认号必定是42.
习题:
3-1
假设客户机A向服务器S发起一个Telnet会话。与此同时,客户机B也向服务器S发起一个Telnet会话。给出下面报文段的源端口号和目的端口号:
从A发往S的报文段
从B发往S的报文段
从S发往A的报文段
从S发往B的报文段
如果A和B是不同的主机,那么从A发往S的报文段的源端口号是否可能与从B发往S的报文段的源端口号相同。
如果他们是同一台主机,情况会怎样?
3-3
UDP和TCP使用反码来计算检验和。假设有下面3个8比特字节01110000这些8比特字节和的反码是多少?(注意到尽管UDP和TCP使用16比特的字来计算检验和,但对于这个问题,应该考虑8比特和。)写出所有工作过程。UDP为什么要用该和的反码,即为什么不直接使用该和呢?使用该反码方案,接收方如何检测出差错?1比特的差错将可能检测不出来吗?2比特的差错呢?
3-18
考虑一个GBN协议,其发送方窗口长度为3,序号范围为1024。假设在时刻t,接收方期待的下一个有序分组的序号是k。假设其中的介质不会对报文重新排序。请回答以下问题:
在t时刻,发送方窗口内的报文序号可能是多少?论证你的回答。
在t时刻,在当前发送方收到的所有报文中,ACK字段的可能值是多少?论证你的回答。
3-20
考虑GBN协议和SR协议。假设序号空间的长度为k,那么为了避免出现图3-27中的问题,允许的最大发送方窗口时多少?
3-22
我们曾经说过,应用程序可能选择UDP作为运输层协议,因为UDP(比TCP)提供了更好的应用层控制,以确定在报文段中发送什么数据和发送时机。
应用层序为什么对报文段中发送什么数据有更多的控制?
应用程序为什么对何时发送报文段有更多的控制?
3-24
3-33
3-35
在3.5.4节中,我们讨论了在发生超时事件后将超时间隔加倍。该机制是拥塞控制的一种形式。为什么TCP除了这种加倍超时间隔机制外,还需要基于窗口的拥塞控制机制呢?
3-37
考虑从一台主机经一条TCP连接向另一台主机发送一个大文件,这条连接不会丢包。
假定TCP使用不具有慢启动的AIMD进行拥塞控制。假设每当收到一批ACK时,CongWin增加1个MSS,往返时间基本恒定,那么CongWin从1MSS增加到6MSS要花费多少时间(假设没有丢包)
对于该连接,直到时间为5RTT,其平均吞吐量是多少(根据MSS和RTT来计算)
4-3
选路和转发的区别是什么
4-9
描述在输入端口会出现分组丢失的原因。描述在输入端口能够消除分组丢失的原因(不使用无限大缓存区)
4-10
描述在输出端口能够出现分组丢失的原因。
4-11
什么是HOL阻塞?它出现在输入端口还是输出端口?
4-15
假设在一个源主机和一个目的主机之间有3台路由器。不考虑分片,一个从源主机发送给目的主机的IP报文将通过多少个接口?为了将数据报从源移动到目的地需要检索多少个转发表?
4-29
定义个对比一下术语:子网、前缀和BGP路由。
4-33
对于我们学习的3种一般的广播通信方法(无控制洪泛、受控洪泛和生成树广播),下列说法正确吗?可以假定分组不会因缓存溢出而丢失,所有分组以它们发送的顺序交付给链路。a.一个节点可能接收到同一个分组的多个拷贝。
b.一个节点可能跨越相同