《计算机网络技术基础》课件第6章_第1页
《计算机网络技术基础》课件第6章_第2页
《计算机网络技术基础》课件第6章_第3页
《计算机网络技术基础》课件第6章_第4页
《计算机网络技术基础》课件第6章_第5页
已阅读5页,还剩78页未读 继续免费阅读

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

第六章

端到端传输协议

6.1OSI/RM模型中的传输层

6.2TCP/IP参考模型中的传输层6.3传输控制协议(TCP)6.4用户数据协议(UDP)本章小结

习题

6.1OSI/RM模型中的传输层

6.1.1传输层端口的概念传输层的任务是根据通信子网的特性最佳地利用网络资源,为两个端系统的会话层之间提供建立、维护和取消传输连接的功能,负责端到端的可靠数据传输。在该层,信息传输的协议数据单元称为段或报文。网络层只是根据网络地址将源节点发出的数据包传输到目的节点,而传输层则负责将数据可靠地传输到相应的端口。计算机网络中的资源子网是通信的发起者和接收者,其中的每个设备称为端点;通信子网提供网络中的通信服务,其中的设备称为节点。OSI参考模型中用于通信控制的有物理层、数据链路层、网络层和传输层,但它们的控制对象不同。6.1.2传输层的基本功能传输层提供了主机应用程序进程之间端到端的服务,基本功能如下:

(1)分割与重组数据。

(2)按端口号寻址。

(3)连接管理。

(4)差错控制和流量控制。传输层要向会话层提供可靠的通信服务,避免报文出现出错、丢失、延迟时间紊乱、重复、乱序等差错。6.1.3传输层的服务类型及协议等级

1.服务类型传输层提供的服务可分为传输连接服务和数据传输服务。

传输连接服务:通常,对会话层要求的每个传输连接,传输层都要在网络层上建立相应的连接。

数据传输服务:强调提供面向连接的可靠服务(很晚OSI才开始制定无连接服务的有关标准),并提供流量控制、差错控制和序列控制,以实现两个终端系统间传输的报文无差错、无丢失、无重复、无乱序。

2.协议等级传输层服务通过协议体现,因此传输层协议的等级与网络服务质量密切相关。根据差错性质,网络服务按质量可分为以下三种类型:

A类服务:低差错率连接,即具有可接受的残留差错率和故障通知率。

C类服务:高差错率连接,即具有不可接受的残留差错率和故障通知率。

B类服务:介于A类服务与C类服务之间。差错率的接受与不可接受是取决于用户的。因此,网络服务质量的划分是以用户要求为依据的。OSI根据传输层的功能特点,定义了以下五种协议级别:

0级:简单连接。只建立一个简单的端到端的传输连接,并可分段传输长报文。

1级:基本差错恢复级。在网络连接断开、网络连接失败或收到一个未被认可的传输连接数据单元等基本差错时,具有恢复功能。

2级:多路复用。允许多条传输共享同一网络连接,并具有相应的流量控制功能。

3级:差错恢复和多路复用。是1级和2级协议的综合。

4级:差错检测、恢复和多路复用。在3级协议的基础上增加了差错检测功能。典型的传输层协议有以下两种:

SPX:顺序包交换协议,是NovellNetWare网络的传输层协议。

TCP:传输控制协议,是TCP/IP参考模型的传输层协议。6.1.4传输层在OSI中的地位和作用传输层是整个协议层次结构的核心,是惟一负责总体数据传输和控制的一层。因为网络层不一定保证服务的可靠,而用户也不能直接对通信子网加以控制,因此在网络层之上加一层即传输层以改善传输质量。传输层利用网络层提供的服务,并通过传输层地址提供给高层用户传输数据的通信端口,使系统间高层资源的共享不必考虑数据通信方面和不可靠的数据传输方面的问题。它的主要功能是:对一个进行的对话或连接提供可靠的传输服务,在通向网络的单一物理连接上实现该连接的复用,在单一连接上提供端到端的序号与流量控制、差错控制及恢复等服务。6.2TCP/IP参考模型中的传输层

6.2.1传输层协议

TCP/IP的传输层提供了两个主要的协议,即传输控制协议(TCP)和用户数据报协议(UDP)。在TCP/IP体系中,根据所使用的协议是TCP或UDP,将所传输的数据分别称为TCP报文段(Segment)或UDP报文、用户数据报。

UDP提供无连接的服务,UDP在传送数据之前不需要建立连接。远程主机的传输层在收到UDP报文后,不需要给出任何确认。

CP则提供面向连接的服务。在传送数据之前必须先建立连接,数据传送结束后要释放连接。TCP不提供广播或多播服务。传输层的UDP用户数据报与网络层的IP数据报有很大的区别。IP数据报要经过互联网中许多路由器的存储转发,但UDP用户数据报是在传输层的端到端抽象的逻辑信道中传送的。IP数据报经过路由器进行转发,用户数据报只是IP数据报中的数据,路由器看不见有用户数据报经过它。

TCP是传输层的连接,它和网络层的虚电路(如X.25使用的)完全不同。TCP报文段是在传输层抽象的端到端逻辑信道中传送的,这种信道是可靠的全双工信道。但这样的信道却不知道究竟经过了多少路由器,而且这些路由器也根本不知道上面的传输层是否建立了TCP连接。然而在X.25建立的虚电路所经过的交换节点中,都必须保存X.25虚电路的状态信息。6.2.2端口和套接字传输层协议实现应用进程间端到端的通信。计算机中的不同进程可能同时进行通信,这时它们会用端口号进行区别,通过网络地址和端口号的组合,即套接字(Socket),达到惟一标识的目的。TCP和UDP都使用端口和套接字。套接字是由IP地址加上端口号组成的。发送套接字 = 源IP地址 + 源端口号接收套接字 = 目的IP地址 + 目的端口号每个端口都拥有一个名为端口号的整数描述符,用来标识不同的端口或进程。在TCP/IP传输层,定义一个16bit长度的整数作为端口标识,也就是说可定义216个端口,其端口号从0到216-1。由于TCP/IP传输层的TCP和UDP协议是两个完全独立的软件模块,因此各自的端口号也相互独立,即各自可独立拥有216个端口。如图6-1所示,每种应用层协议或应用程序都具有与传输层惟一连接的端口,并且使用惟一的端口号将这些端口区分开来。当数据流从某一个应用发送到远程网络的某一个应用时,传输层根据这些端口号,就能够判断出数据来自于哪一个应用,想要访问另一台网络的哪一个应用,从而将数据传递到相应的应用层协议或应用程序。图6-1应用层与传输层之间的接口

1.保留端口这种端口的端口号一般都小于1024。它们基本上都被分配给了已知的应用协议(如表6-1中的部分端口)。目前,这一类端口的端口号分配已经被广大网络应用者接受,形成了标准,在各种网络的应用中调用这些端口号就意味着使用它们所代表的应用协议。这些端口由于已经有了固定的使用者,所以不能被动态地分配给其他应用程序。表6-1给出了一些常用的保留端口。表6-1TCP协议和UDP协议的一些常用保留端口UDP保留端口举例端口号关键字应用协议53DNS域名服务69TFTP简单文件传输协议161SNMP简单网络管理协议520RIPRIP路由选择协议TCP保留端口举例21FTP文件传输协议23Telnet虚拟终端协议25SMTP简单邮件传输协议53DNS域名服务80HTTP超文本传输协议119NNTP网络新闻传输协议

2.动态分配的端口这种端口的端口号一般都大于1024。这一类端口没有固定的使用者,它们可以被动态地分配给应用程序。也就是说,在使用应用软件访问网络的时候,应用软件可以向系统申请一个大于1024的端口号临时代表这个软件与传输层交换数据,并且使用这个临时的端口与网络上的其他主机通信。图6-2显示了使用动态分配的端口访问网络资源的情况。它显示的是在使用微软公司的IE浏览器上网时,在DOS窗口中使用netstat命令查看端口使用情况的画面。IE浏览器使用了3693、3692等多个动态分配的端口号。图6-2查询动态分配的端口访问网络资源

3.注册端口注册端口比较特殊,它也是固定为某个应用服务的端口,但是它所代表的不是已经形成标准的应用层协议,而是某个软件厂商开发的应用程序。某些软件厂商通过使用注册端口,使它的特定软件享有固定的端口号,而不用向系统申请动态分配的端口号。一般情况下,这些特定的软件要使用注册端口,其厂商必须向端口的管理机构注册。大多数注册端口的端口号大于1024。

TCP协议和UDP协议都允许16位的端口值,分别能够提供65536个端口。不论端口号大于还是小于1024,以上三种端口都分别属于TCP协议和UDP协议。当然,也有些端口既属于TCP协议也属于UDP协议。当网络中的两台主机进行通信时,为了表明数据是由源端的哪一种应用发出的,以及数据所要访问的是目的端的哪一种服务,TCP/IP协议会在传输层封装数据段时,把发出数据的应用程序的端口作为源端口,把接收数据的应用程序的端口作为目的端口,添加到数据段的头中,从而使主机能够同时维持多个会话的连接,使不同应用程序的数据不至于混淆。一台主机上的多个应用程序可同时与其他多台主机上的多个对等进程进行通信,所以需要对不同的虚电路进行标识。对TCP虚电路连接采用发送端和接收端的套接字(Socket)组合来识别,形如Socket1、Socket2。所谓套接字实际上是一个通信端点,每个套接字都有一个套接字序号,包括主机的IP地址与一个16位的主机端口号。源端口与目的端口示意图如图6-3所示。图6-3端口的示意图6.3传输控制协议(TCP)

6.3.1TCP协议格式

1.

TCP报文段的格式

TCP的协议数据单元被称为报文段(Segment),TCP通过报文段的交互来建立连接、传输数据、发出确认、进行差错控制、流量控制及关闭连接。报文段分为两部分,即报文段头和数据,所谓报文段头就是TCP为了实现端到端可靠传输所加入的控制信息,而数据则是指由高层即应用层来的数据。图6-4给出了TCP报文段头的格式。其中有关字段的说明如下。源端口:占16bit,报文段的源端口号。目标端口:占16bit,报文段的目的端口号。序号:占32bit。TCP是面向数据流的,TCP传送的报文可看做连续的数据流。在TCP传送的数据流中,每一个字节都有一个序号,报文段的序列号表示该报文段在发送方的数据流中的位置,用来保证数据到达的顺序性。确认号:占32bit,是期望收到对方的下一个TCP报文段的数据的第一个字节的序号,相当于是对对方所发送的并已被己方所正确接收的报文段的确认。序号和确认号共同用于TCP服务中的确认、差错控制。数据偏移:占4bit,它指出TCP报文段的数据起始处与TCP报文段的起始处的距离。这实际上就是TCP报文段首部的长度。由于首部长度不固定,因此数据偏移字段是必要的。保留:占6bit,为将来的应用而保留,目前置为“0”。编码位:占6bit,TCP报文段有多种应用,如建立或关闭连接、传输数据、携带确认等,这些编码位用于给出与报文段的作用及处理有关的控制信息。图6-4TCP报文段头的格式窗口:占32bit,窗口字段用来控制对方发送的数据量,单位为字节。使用可变大小的滑动窗口协议来进行流量控制。校验和:占32bit,用于对报文段首部和数据进行校验。紧急指针:占16bit,给出从当前顺序号到紧急数据位置的偏移量。

任选项:长度可变。TCP只规定了一种选项,即最大报文段长度(MSS,MaximumSegmentSize)。MSS告诉对方TCP:“我的缓存所能接收的报文段的数据字段的最大长度是MSS个字节”。当没有使用选项时,TCP的首部长度是20字节。填充:当任选项字段长度不足32位字长时,需要加以填充。数据:来自高层即应用层的协议数据。2.序号与确认TCP不是按传送的报文段来编号的。TCP将所要传送的整个报文(可能包括许多个报文段)看成一个个字节组成的数据流,然后对每一个数据流编一个序号。在连接建立时,双方要商定初始序号。TCP就将每一次所传送的报文段中的第一个数据字节的序号,放在TCP首部的序号字段中。TCP的确认是对接收到的数据的最高序号(即收到的数据流中的最后一个序号)表示确认,但返回的确认序号是已收到的数据的最高序号加1。也就是说,确认序号表示期望下次收到的第一个数据字节的序号。由于TCP能提供全双工通信,因此通信中的每一方都不必专门发送确认报文段,而可以在传送数据时顺便把确认信息捎带传送。若发送方在规定的设置时间内没有收到确认,就要将未被确认的报文段重新发送。接收方若收到有差错的报文段,则丢弃此报文段而并不发送否认信息。若收到重复的报文段,也要将其丢弃,但要发回(或捎带发回)确认信息。这与数据链路层的情况相似。3.

TCP连接的建立和拆除TCP连接包括建立连接、数据传输和拆除连接三个过程。TCP通过TCP端口提供连接服务,最后通过连接服务来接收和发送数据。TCP连接的申请、打开和关闭必须遵守TCP协议的规定。TCP使用三次握手协议来建立连接。连接可以由任何一方发起,也可以由双方同时发起。一旦一台主机上的TCP软件已经主动发起连接请求,运行在另一台主机上的TCP软件就被动地等待握手。图6-5给出了三次握手建立TCP连接的简单示意图。图6-5三次握手建立TCP连接1)建立连接在源主机想与目的主机通信时,目的主机必须同意,否则TCP连接无法建立。为了确保TCP连接的成功建立,TCP采用了一种称为三次握手的方式,三次握手方式使得“序号/确认号”系统能够正常工作,从而使它们的序号达成同步。如果三次握手成功,则连接建立成功,可以开始传送数据信息。三次握手分别为:第一步:源主机A的TCP向主机B发出连接请求报文段,其首部中的SYN(同步)标志位应置为1,表示想与目标主机B进行通信,并发送一个同步序列号x(例:SEQ = 100)进行同步,表明在后面传送数据时第一个数据字节的序号是x +

1(即101)。第二步:目标主机B的TCP收到连接请求报文段后,如同意,则发回确认。在确认报中应将ACK位和SYN位置1。确认号应为x + 1(图6-5中为101),同时也为自己选择一个序号y。第三步:源主机A的TCP收到目标主机B的确认后要向目标主机B发出确认,其ACK置1,确认号为y + 1,而自己的序号为x + 1。TCP的标准规定,SYN置1的报文段要消耗掉一个序号。运行客户进程的源主机A的TCP通知上层应用进程,连接已经建立。当源主机A向目标主机B发送第一个数据报文段时,其序号仍为x + 1,因为前一个确认报文段并不消耗序号。当运行服务进程的目标主机B的TCP收到源主机A的确认后,也通知其上层应用进程,连接已经建立。至此建立了一个全双工的连接。2)传送数据位于TCP/IP分层模型较上层的应用程序传输数据流给TCP。TCP接收到字节流并且把它们分解成段。假如数据流不能被分成一段,那么每一个段都被分给一个序列号。在目的主机端,这个序列号用来把接收到的段重新排序成原来的数据流。图6-6给出了两台主机在成功建立连接后传输数据的示例。图6-6发送四个数据段的过程(1)主机A使用滑动窗口发送全部的四个数据段到主机B,这是第一步。不幸的是,只有段l03、105和106成功地到达了主机B(参看②)。(2)因为段103和104是连续的,所以主机B返回一个确认给主机A,通知主机A它只成功地接收到了第103段,在它的确认中主机B使用它期待得到的下一个序列号作为确认(参看③通过给出序列号104)。(3)主机A接到主机B的报文后,重新发送数据104、105和106(参看④)。虽然主机B已经成功地收到了段105和106,但是根据协议规定,也必须重新发送。(4)当主机2成功地收到这些段以后,主机B返回一个确认给主机A(参看⑥),并根据序列号把它们重组成原来的数据流。把它传输到高层应用程序。3)关闭连接一个TCP连接建立之后,即可发送数据,一旦数据发送结束,就需要关闭连接。由于TCP连接是一个全双工的数据通道,一个连接的关闭必须由通信双方共同完成。当通信的一方没有数据需要发送给对方时,可以使用FIN段向对方发送关闭连接请求。这时,它虽然不再发送数据,但并不排斥在这个连接上继续接收数据。只有当通信的对方也递交了关闭连接的请求后,这个TCP连接才会完全关闭。在关闭连接时,既可以由一方发起而另一方响应,也可以双方同时发起。无论怎样,收到关闭连接请求的一方必须使用ACK段给予确认。实际上,TCP连接的关闭过程也是一个三次握手的过程。在关闭连接之前,为了确保数据正确传递完毕,仍然需要采用三次握手的方式来关闭连接,如图6-7所示。图6-7TCP连接释放的过程其三次握手分别为:第一步:源主机A的应用进程先向其TCP发出连接释放请求,并且不再发送数据。TCP通知对方要释放从A到B这个方向的连接,将发往主机B的TCP报文段首部的终止位FIN置1,其序号x等于前面已传送过的数据的最后一个字节的序号加1。第二步:目标主机B的TCP收到释放连接通知后即发出确认,其序号为y,确认号为x + 1,同时通知高层应用进程,如图6-7中的箭头①所示。这样,从A到B的连接就释放了,连接处于半关闭状态,相当于主机A向主机B说:“我已经没有数据要发送了,但如果还发送数据,我仍接收。”此后,主机B不再接收主机A发来的数据。但若主机B还有一些数据要发送主机A,则可以继续发送。主机A只要正确收到数据,仍应向主机B发送确认。第三步:若主机B不再向主机A发送数据,其应用进程通知TCP释放连接,如图6-7中的箭头②所示。主机B发出的连接释放报文段必须将终止位FIN和确认位ACK置1,并使其序号仍为y,但还必须重复上次已发送过的ACK = x

+ 1。主机A必须对此发出确认,将ACK置1,ACK = y + 1,而自己的序号是x + 1。这样才把从B到A的反方向的连接释放掉。主机A的TCP再向其应用进程报告,整个连接已经全部释放。6.3.2TCP可靠数据传输技术TCP协议采用了许多与数据链路层类似的机制来保证可靠的数据传输,如采用序列号、确认、滑动窗口协议等。只不过TCP协议的目的是为了实现端到端节点之间的可靠数据传输,而数据链路层协议则是为了实现相邻节点之间的可靠数据传输。首先,TCP要为所发送的每一个报文段加上序列号,保证每一个报文段能被接收方接收,并只被正确地接收一次。其次,TCP采用具有重传功能的积极确认技术作为可靠数据流传输服务的基础。这里,“确认”是指接收端在正确收到报文段之后向发送端回送一个确认(ACK)信息。发送方将每个已发送的报文段备份在自己的发送缓冲区里,而且在收到相应的确认之前是不会丢弃所保存的报文段的。“积极”是指发送方在每一个报文段发送完毕的同时启动一个定时器,假如定时器的定时期满而关于报文段的确认信息尚未到达,则发送方认为该报文段已丢失并主动重发。为了避免由于网络延迟引起迟到的确认和重复的确认,TCP规定在确认信息中捎带一个报文段的序号,使接收方能正确地将报文段与确认联系起来。第三,采用可变长的滑动窗口协议进行流量控制,以防止由于发送端与接收端之间的不匹配而引起数据丢失。这里所采用的滑动窗口协议与数据链路层的滑动窗口协议在工作原理上是完全相同的,惟一的区别在于滑动窗口协议用于传输层是为了在端到端节点之间实现流量控制,而用于数据链路层是为了在相邻节点之间实现流量控制。TCP采用可变长的滑动窗口,使得发送端与接收端可根据自己的CPU和数据缓存资源对数据发送和接收能力来作出动态调整,从而灵活性更强,也更合理。6.3.3TCP流量控制与拥塞控制TCP初始连接一旦建立,两端就能够使用全双工通信交换数据段,并缓存所发送和接收的报文段。缓存所发送的报文段是为了重传的需要,以防止报文段不能到达或不能按顺序到达接收端引起的差错。1.流量控制TCP采用大小可变的滑动窗口机制实现流量控制功能。窗口大小的单位为字节。在TCP报文段首部的窗口字段写入的数值就是当前给对方设置的发送窗口数据的上限。在数据传输过程中,TCP提供了一种基于滑动窗口协议的流量控制机制,用接收端接收能力(缓冲区的容量)的大小来控制发送端发送的数据量。在建立连接时,通信双方使用SYN报文段或ACK报文段中的窗口字段捎带着各自的接收窗口尺寸,即通知对方从而确定对方发送窗口的上限。在数据传输过程中,发送方按接收方通知的窗口尺寸和序号发送一定量的数据,接收方根据接收缓冲区的使用情况动态调整接收窗口尺寸,并在发送TCP报文段或确认段时捎带新的窗口尺寸和确认号通知发送方。如图6-8所示。设主机A向主机B发送数据。双方确定的窗口值是400。设一个报文段为100字节长,序号的初始值为1(即SEQ = 1)。在图6-8中,主机B进行了三次流量控制。第一次将窗口减小为300字节,第二次将窗口又减为200字节,最后一次减至零,即不允许对方再发送数据了。这种暂停状态将持续到主机B重新发出一个新的窗口值为止。图6-8利用可变滑动窗口进行流量控制

2.拥塞控制采用滑动窗口机制还可对网络进行拥塞控制,将网络中的分组(TCP报文段作为其数据部分)数量维持在一定的数量之下,当超过该数值时,网络的性能会急剧恶化。传输层的拥塞控制有慢启动(Slow-Start)、拥塞避免(CongestionAvoidance)、快重传(FastRetransmit)和快恢复(FastRecovery)四种算法。

6.3.4重发机制重发机制是TCP中最重要、最复杂的问题之一。TCP每发送一个报文段,就设置一次定时器。只要定时器设置的重发时间到而还没有收到确认,就要重发这一报文段。大家知道,TCP是在互联网的环境下工作,发送的报文段可能只经过一个高速率的局域网,但也可能经过多个低速率的广域网,报文段的端到端时延会相差很多倍。那么,定时器的重发时间究竟应设置为多大?

TCP采用了一种自适应算法。这种算法记录每一个报文段发出的时间,以及收到相应的确认报文段的时间,这两个时间之差就是报文段的往返时延。将各个报文段的往返时延样本加权平均,就得出报文段的平均往返时延T。6.4用户数据协议(UDP)

UDP只在IP的数据报服务之上增加了很少的功能,即端口的功能(有了端口,传输层就能进行复用和分用)和差错检测的功能。UDP在某些方面有其特殊的优点:

(1)发送数据之前不需要建立连接,减少了开销和发送数据之前的时延。

(2) UDP不使用拥塞控制,也不保证可靠交付,因此主机不需要维持具有许多参数而又复杂的连接状态表。

(3) UDP用户数据报只有8个字节的首部。

(4)由于UDP没有拥塞控制,因此网络出现的拥塞不会使源主机的发送效率降低,这对某些实时应用是很重要的。很多的实时应用(如IP电话、实时视频会议等)要求源主机以恒定的速度发送数据,并且允许在网络发生拥塞时丢失一些数据,但却不允许数据有太大的时延,UDP正好能满足这种要求。

UDP常用于一次性传输数据量较小的网络应用,如SNMP、DNS等应用数据的传输。因为对于这些一次性传输数据量较小的网络应用,若采用TCP服务,则所付出的关于连接建立、维护和拆除的开销是非常不合算的。表6-2列出了一些应用和应用层协议主要使用的传输层协议。表6-2应用层协议使用的传输层协议6.4.1UDP数据报的首部格式

UDP有两个字段:数据字段和首部字段。首部字段只有8个字节,由4个字段组成,每个字段都是两个字节。如图6-9所示。各字段意义如下:源端口:占16bit,源端口号。目的端口:占16bit,目的端口号。

UDP报文长度:占16bit,UDP用户数据报的长度。校验和:占16bit,防止UDP用户数据报在传输中出错。在UDP协议中也采用与TCP中类似的端口概念来标识同一主机上的不同网络进程,并且两者在分配方式上也是类似的。UDP与应用层之间的端口都是用报文队列来实现的。图6-9UDP数据报的首部6.4.2UDP报文的发送和接收如同TCP报文一样,UDP报文也是通过IP协议来发送和接收的。在发送数据时,UDP实体构造好UDP报文后,交付给IP协议,IP协议将整个UDP报文封装在IP数据报中,形成IP数据报(如图6-9所示)发送到网络中。在接收数据时,UDP实体判断UDP报文的目的端口是否与当前使用的某个端口匹配。若匹配,则将报文存入接收队列;若不匹配,则向源端发送一个端口不可达的ICMP报文,同时丢弃UDP报文。6.4.3TCP与UDP的区别

TCP传输控制协议提供的是面向连接、可靠的字节流服务。当客户和服务器彼此交换数据前,必须先在双方之间建立一个TCP连接,之后才能传输数据。TCP提供超时重发、丢弃重复数据、检验数据、流量控制等功能,保证数据能从一端传到另一端。

UDP用户数据报协议是一个简单的面向数据报的运输层协议。UDP不提供可靠性,它只是把应用程序传给IP层的数据报发送出去,但是并不能保证它们能到达目的地。由于UDP在传输数据报前不用在客户和服务器之间建立一个连接,且没有超时重发等机制,故传输速度很快。

TCP协议和UDP协议的一些特性区别如下:

(1) TCP协议在传送数据段的时候要给段标号;UDP协议无需对数据段编号。

(2) TCP协议可靠;UDP协议不可靠。

(3) TCP协议是面向连接的;UDP协议面向无连接。

(4) TCP协议负载较高,采用虚电路;UDP协议低负载。

(5) TCP协议的发送方要确认接受方是否收到数据段(三次握手协议)。

(6) TCP协议采用基于滑动窗口技术的流量控制机制。本章小结传输层是整个协议层次的核心,其功能是为源主机到目的主机提供可靠、价格低廉的数据传输,而与当前使用的网络无关。本章主要介绍传输层的基本概念,包括:传输层提供给高层的服务、传输层的两种连接方式,其中特别应明确传输层的寻址与网络层的寻址的区别。传输层协议的复杂程度取决于网络传输质量和网络层服务的水平。传输层功能的实质是最终完成端到端的可靠连接,在此,要特别明确“端”是指用户应用程序的“端口”,即传输层的“地址”要落实到端口号。本章重点介绍了因特网中的两种传输层协议TCP和UDP,详细分析了TCP中连接建立和释放的过程及原理,比较了TCP和UDP各自的特点习题一、名词解释端口套接字二、填空题

1.在IP互联网中,

是传输层最重要的两种协议,它们为上层用户提供不同级别的通信可靠性。

2. TCP可以提供

服务。UDP可以提供

服务。

3.在TCP/IP体系中,根据所使用的协议是TCP或UDP,将所传输的数据分别称为

4. TCP连接包括

三个过程。

5. TCP采用

机制实现流量控制功能。

6.传输层的拥塞控制有

四种算法。

7. TCP通过

提供连接服务,最后通过连接服务来接收和发送数据。

8.在TCP协议报头中包括

6个字段,其中

用于建立连接,

用于复位一个连接,

用于标志紧急数据,而

确认是否有效。三、选择题

1.为了保证连接的可靠性,TCP通常采用()。

A.三次握手法 B.窗口控制机制

C.端口机制 D.自动重发机制

2.在TCP/IP协议簇中,UDP协议工作在()。

A.应用层 B.传输层

C.网络互联层 D.网络接口层

3.关于TCP和UDP,下列说法中错误的是()。

A. TCP和UDP的端口号是相互独立的

B. TCP和UDP的端口号是完全相同的,没有本质区别

C.在利用TCP发送数据前,需要与对方建立一条TCP连接

D.在利用UDP发送数据前,不需要与对方建立连接

4.三次握手方法用于()。

A.传输层连接的建立

B.数据链路层的流量控制

C.传输层的重复检测

D.传输层的流量控制

5.传输层可以通过()标识不同的应用。

A.物理地址 B.端口号

C. IP地址 D.逻辑地址

6~10.基于TCP/IP的因特网服务中,IP协议提供主机之间的(6)分组传输服务。TCP协议提供端口之间的(7)报文传输服务;为了实现可靠的服务,采用超时重传、确认捎带技术。传输中的协议规定,在确认信息中捎带(8)的序号以减少通信量。TCP使用三次握手协议来建立连接,设甲乙双方发送报文的初始序号分别为x和y,甲方发送(9)的报文给乙方,乙方接收报文后发送(10)的报文给甲方,然后甲方发送一个确认报文给乙,从而建立了连接。

温馨提示

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

评论

0/150

提交评论