1、第第3章章 传输层协议传输层协议UDP和和TCP第3章 传输层协议UDP和TCP 3.1 端到端通信和端口号端到端通信和端口号3.2 用户数据报协议用户数据报协议UDP 3.3 传输控制协议传输控制协议TCP3.4 TCP与与UDP的比较的比较习题习题 第第3章章 传输层协议传输层协议UDP和和TCP3.1 端到端通信和端口号端到端通信和端口号3.1.1 端到端通信在互联网中,任何两台通信的主机之间,从源端到目标端的信道都是由一段一段的点到点通信线路组成的(一个局域网中两台主机通信时只有一段点到点的线路)。如图3-1所示。 第第3章章 传输层协议传输层协议UDP和和TCP主机1路由器路由器主机
2、2端到端点到点点到点点到点网络1网络2图3-1 传输层端到端通信第第3章章 传输层协议传输层协议UDP和和TCP由第2章的知识可知,点到点通信是由网络互联层来实现的,网络互联层只屏蔽了不同网络之间的差异,构建了一个逻辑上的通信网络,因此它只解决了数据通信问题。 端到端通信是建立在点到点通信基础之上的,它是比网络互联层通信更高一级的通信方式,完成应用程序(进程)之间的通信。端到端的通信是由传输层来实现的。 第第3章章 传输层协议传输层协议UDP和和TCP3.1.2 传输层端口的概念为了识别传输层之上不同的网络通信程序(进程),传输层引入了端口的概念。在一台主机上,要进行网络通信的进程首先要向系统
3、提出动态申请,由系统(操作系统内核)返回一个本地惟一的端口号,进程再通过系统调用把自己和这个特定的端口联系在一起,这个过程叫绑定(Binding)。这样,每个要通信的进程都与一个端口号对应,传输层就可以使用其报文头中的端口号,把收到的数据送到不同的应用程序,如图3-2所示。第第3章章 传输层协议传输层协议UDP和和TCP应用程序应用程序应用程序应用程序ICMPTCPUDPARPIPRARP以太网网络接口层以太网由传输层报头中的端口字段标识由IP数据报头中的上层协议字段标识由以太网帧类型字段标识图3-2 传输层端到端通信 第第3章章 传输层协议传输层协议UDP和和TCP在TCP/IP协议中,传输
4、层使用的端口号用一个16位的二进制数表示。因此,在传输层如果使用TCP协议进行进程通信,则可用的端口号共有216个。由于UDP也是传输层一个独立于TCP的协议,因此使用UDP协议时也有216个不同的端口。一些常用服务的TCP和UDP的众所周知端口号见表3-1和表3-2。 第第3章章 传输层协议传输层协议UDP和和TCP表3-1 常用的众所周知的TCP端口号TCP 端口号 关键词 描 述 20 FTP-DATA 文件传输协议(数据连接) 21 FTP 文件传输协议(控制连接) 23 Telnet 远程登录协议 25 SMTP 简单邮件传输协议 53 Domain 域名服务器 80 HTTP 超文
5、本传输协议 110 POP3 邮局协议 3 119 NNTP 网络新闻传递协议 第第3章章 传输层协议传输层协议UDP和和TCP表3-2 常用的众所周知的UDP端口号UDP 端口号 关键词 描 述 53 Domain 域名服务器 67 BootPS 引导协议服务器 68 BootPC 引导协议客户机 69 TFTP 简单文件传输协议 161 SNMP 简单网络管理协议 162 SNMP-TRAP 简单网络管理协议陷阱 第第3章章 传输层协议传输层协议UDP和和TCP 2561023之间的端口号通常都是由Unix系统占用的,以提供一些特定的Unix服务。现在IANA管理11023之间所有的端口号
6、。任何TCP/IP实现所提供的服务都使用11023之间的端口号。 客户端口号又称为临时端口号(即存在时间很短暂)。这是因为客户端口号是在客户程序要进行通信之前,动态地从系统申请的一个端口号,然后以该端口号为源端口,使用某个众所周知的端口号为目标端口号(如在TCP协议上要进行文件传输时使用21)进行客户端到服务器端的通信。综上所述,我们知道两台要通信的主机,每一端要使用一个二元地址(IP地址,端口号)才可以完成它们之间的通信。 第第3章章 传输层协议传输层协议UDP和和TCP3.2 用户数据报协议用户数据报协议UDP 3.2.1 UDP数据报的封装及其格式UDP协议在工作时是建立在IP协议之上的
7、,UDP从进程的缓冲区接收进程每一次产生的输出,对每次输出都生成一个UDP数据报,然后把生成的UDP数据报直接封装在IP数据报中进行传输,因此在传输层使用UDP协议时,发送端不需要发送缓冲区,如图3-3所示。 第第3章章 传输层协议传输层协议UDP和和TCPUDP数据报头区UDP数据区IP数据区IP报头区UDP数据报IP数据报图3-3 UDP数据报的封装 第第3章章 传输层协议传输层协议UDP和和TCP被封装在IP中的UDP数据报通过网络传输到目标主机的IP层后,由目标主机的UDP层根据目标端口号送到接收该数据的相应进程。UDP数据报的格式如图3-4所示。 第第3章章 传输层协议传输层协议UD
8、P和和TCPUDP目标端口号(16位)015 1631UDP源端口号(16位)UDP长度(16位)UDP校验和(16位) 数 据 区图3-4 UDP数据报格式 第第3章章 传输层协议传输层协议UDP和和TCP3.2.2 UDP校验和的计算方法 顾名思义,这个伪头部并不是UDP的真正组成部分,它只是为了UDP在进行差错检查时可以把更多的信息包含进去而人为加上的。伪头部的格式如图3-5所示。 第第3章章 传输层协议传输层协议UDP和和TCP协议(8位,UDP值为17)UDP长度(16位)填充域(8位,全0)目标端IP地址(32位)源 端IP地 址(32位)015 16317 8图3-5 UDP伪头
9、部格式 第第3章章 传输层协议传输层协议UDP和和TCP伪头部包含IP头部的一些字段,填充域全填0,目的是使伪头部为16位二进制数的整数倍,这是计算校验和时所需要的。协议字段的值为17(表示为UDP协议,见表2-4),UDP长度为UDP数据报的总长(当然不能包括虚构的伪头部)。源端在发送UDP数据报时,使用构造的UDP伪头部和UDP数据报计算出校验和(校验和计算方法与IP头部校验和的计算方法相同),然后填入UDP头部。 第第3章章 传输层协议传输层协议UDP和和TCP3.2.3 UDP协议的特点从UDP协议的数据报格式可以看出,UDP对数据的封装非常简单,主要是增加了端口号与校验和,然后就可以
10、直接通过IP层进行传输了,因此它具有以下特点: (1) UDP是一种无连接、不可靠的数据报传输服务协议。 (2) UDP对数据传输过程中惟一的可靠保证措施是进行差错校验,如果发生差错,则只是简单地抛弃该数据报。(3) 如果目标端收到的UDP数据报中的目标端口号不能与当前已使用的某端口号匹配,则将该数据报抛弃,并发送目标端口不可达的ICMP差错报文。第第3章章 传输层协议传输层协议UDP和和TCP(4) UDP协议在设计时的简单性,是为了保证UDP在工作时的高效性和低延时性。因此,在服务质量较高的网络中(如局域网),UDP可以高效地工作。 (5) UDP常用于传输延时小,对可靠性要求不高,有少量
11、数据要进行传输的情况,如DNS(域名服务)、TFTP(简单文件传输)等。第第3章章 传输层协议传输层协议UDP和和TCP3.3 传输控制协议TCP3.3.1 TCP报文段格式TCP报文段(常称为段)与UDP数据报一样也是封装在IP中进行传输的,只是IP报文的数据区为TCP报文段。TCP报文段的格式如图3-6所示。第第3章章 传输层协议传输层协议UDP和和TCPTCP目标端口号(16位)0151631TCP源端口号(16位)序列号(32位)窗口大小(16位)确认号(32位)FINSYNRSTPSHACKURG保留(6位)首部长度(4位)校 验 和(16位)紧急指针(16位)选项 填充 数 据 区
12、图3-6 TCP报文段的格式第第3章章 传输层协议传输层协议UDP和和TCP1TCP源端口号 TCP源端口号长度为16位,用于标识发送方通信进程的端口。目标端在收到TCP报文段后,可以用源端口号和源IP地址标识报文的返回地址。2TCP目标端口号TCP目标端口号长度为16位,用于标识接收方通信进程的端口。源端口号与IP头部中的源端IP地址,目标端口号与目标端IP地址,这4个数就可以惟一确定从源端到目标端的一对TCP连接。3序列号序列号长度为32位,用于标识TCP发送端向TCP接收端发送数据字节流的序号。 第第3章章 传输层协议传输层协议UDP和和TCP4确认号确认号长度为32位。5头部长度该字段
13、用4位二进制数表示TCP头部的长短,它以32位二进制数为一个计数单位。TCP头部长度一般为20个字节,因此通常它的值为5。 6保留保留字段长度为6位,该域必须置0,准备为将来定义TCP新功能时使用。第第3章章 传输层协议传输层协议UDP和和TCP7标志标志域长度为6位,每1位标志可以打开或关闭一个控制功能,这些控制功能与连接的管理(3.3.2小节讲述)和数据传输控制有关,其内容如下所述:URG:紧急指针标志,置1时紧急指针有效。ACK:确认号标志,置1时确认号有效。如果ACK为0,那么TCP头部中包含的确认号字段应被忽略。PSH:push操作标志,当置1时表示要对数据进行push操作。 RST
14、:连接复位标志,表示由于主机崩溃或其他原因而出现错误时的连接。 第第3章章 传输层协议传输层协议UDP和和TCPSYN:同步序列号标志,它用来发起一个连接的建立,也就是说,只有在连接建立的过程中SYN才被置1。FIN:连接终止标志,当一端发送FIN标志置1的报文时,告诉另一端已无数据可发送,即已完成了数据发送任务,但它还可以继续接收数据。第第3章章 传输层协议传输层协议UDP和和TCP8窗口大小窗口大小字段长度为16位,它是接收端的流量控制措施,用来告诉另一端它的数据接收能力。9校验和校验和字段长度为16位,用于进行差错校验。校验和覆盖了整个的TCP报文段的头部和数据区。 10紧急指针紧急指针
15、字段长度为16位,只有当URG标志置1时紧急指针才有效,它的值指向紧急数据最后一个字节的位置(如果把它的值与TCP头部中的序列号相加,则表示紧急数据最后一个字节的序号,在有些实现中指向最后一个字节的下一个字节)。 第第3章章 传输层协议传输层协议UDP和和TCP11选项选项的长度不固定,通过选项使TCP可以提供一些额外的功能。每个选项由选项类型(占1个字节)、该选项的总长度(占1个字节)和选项值组成,如图3-7所示。 选项类型(1个字节)总长度(1个字节)选项值(有些选项没有选项值)图3-7 TCP选项格式第第3章章 传输层协议传输层协议UDP和和TCP当前已定义的选项如表3-3所示。选项类型
16、字段为0和1的选项仅各占1个字节,其他的选项在选项类型后说明了其总长度。12填充填充字段的长度不定,用于填充以保证TCP头部的长度为32位的整数倍,值全为0。第第3章章 传输层协议传输层协议UDP和和TCP表3-3 TCP 选 项表略表略第第3章章 传输层协议传输层协议UDP和和TCP3.3.2 TCP连接的建立与关闭TCP是一个面向连接的协议,TCP协议的高可靠性是通过发送数据前先建立连接,结束数据传输时关闭连接,在数据传输过程中进行超时重发、流量控制和数据确认,对乱序数据进行重排以及前面讲过的校验和等机制来实现的。 TCP在IP之上工作,IP本身是一个无连接的协议,在无连接的协议之上要建立
17、连接,对初学者来说,这是一个较难理解的一个问题。 第第3章章 传输层协议传输层协议UDP和和TCP1. 建立连接TCP使用“三次握手”(3-way Handshake)法来建立一条连接。所谓三次握手,就是指在建立一条连接时通信双方要交换三次报文。具体过程如下。2关闭连接由于TCP是一个全双工协议,因此在通信过程中两台主机都可以独立地发送数据,完成数据发送的任何一方可以提出关闭连接的请求。关闭连接时,由于在每个传输方向既要发送一个关闭连接的报文段,又要接收对方的确认报文段,因此关闭一个连接要经过4次握手。第第3章章 传输层协议传输层协议UDP和和TCP连接建立和关闭的过程可以用图3-8表示,该图
18、是通信双方正常工作时的情况。关闭连接时,图中的u表示服务器已收到数据的序列号,v表示客户机已收到数据的序列号。 第第3章章 传输层协议传输层协议UDP和和TCP客户机进程服务器进程SYN1 SEQxSYN1 SEQy ACKx1SEQx1 ACKy1第一次握手第三次握手传输数据第二次握手第一次握手FIN1 SEQuACKu1FIN1 SEQvACKv1第四次握手第二次握手第三次握手图3-8 TCP连接的建立与关闭 第第3章章 传输层协议传输层协议UDP和和TCP3.3.3 TCP的流量控制和拥塞控制机制 下面我们来看一个实例,图3-9是主机1和主机2使用TCP协议在实际通信时的时序图。 第第3
19、章章 传输层协议传输层协议UDP和和TCPSYN1 SEQx WIN2048 MSS1024SYN1 SEQy ACKx1 WIN2048 MSS1024ACKy1 WIN20481:1024(1024)ACK WIN20481025:2048(1024)ACK WIN2048ACK2049 WIN10242049:3072(1024)ACK WIN2048ACK3073 WIN0ACK3073 WIN20483073:4096(1024)ACK WIN20484097:5120(1024)ACK WIN2048111075431主机1主机22689图3-9 TCP连接的建立与关闭 第第3章章
20、 传输层协议传输层协议UDP和和TCP在图3-9中,主机1连续发送了两个报文段4和5,其长度都为1024个字节,这两个报文段的数据用来填充接收方(主机2)所通知的窗口,由于主机2通知的窗口大小只有2048个字节,这时主机2的缓冲区已经被填满,因此主机1停下来等待一个主机2的确认。发送端发送数据的过程是如何受到接收方控制的,这可以用图3-10表示。报文段2通知的窗口大小为2048个字节,因此主机1的前两个1024个字节的数据块落入窗口内,如图3-10(a)所示,窗口内的数据是可以立即发送的数据。图3-10(b)是图3-9中主机1发送了报文段4和5后的情况,窗口内的数据已发送完毕(用灰色表示),主
21、机1只能等待。第第3章章 传输层协议传输层协议UDP和和TCP图3-10(c)是主机2收到前2048个字节发送了确认报文段6窗口右移后的情况,由于报文段6通知的接收方窗口大小只有1024个字节,因此只有一个1024个字节的数据块落入窗口内。图3-10(d)是主机1对主机2发送了报文段7后的情况,这时窗口内的数据已发送完毕,主机又进入等待状态。图3-9中确认报文段8对收到的前3072个字节进行了确认,但通知的窗口大小为0,如图3-10(e)所示,这时窗口的左边沿到达右边沿,即窗口的长度变为0,称其为一个0窗口,此时发送方不能再发送任何数据,只能等待。等待一段时间后,由于主机2的应用进程从TCP缓
22、冲区中读走了2048个字节的数据,因此由窗口更新报文段9通知的窗口大小为2048个字节,如图3-10(f)所示,这时主机1又可以发送数据了。 第第3章章 传输层协议传输层协议UDP和和TCP(e)(f)1:10241025:20482049:30723073:40964097:5120(a)1:1024 1025:2048 2049:3072 3073:40964097:5120(c)1:1024 1025:20482049:30723073:40964097:51201:10241025:2048 2049:30723073:40964097:5120(b)1:1024 1025:2048
23、2049:30723073:40964097:5120(d)1:1024 1025:20482049:30723073:40964097:5120图3-10 TCP流量控制机制滑动窗口协议 第第3章章 传输层协议传输层协议UDP和和TCP上述流量控制策略中,使用接收方通知的一个窗口大小来控制数据的发送,窗口的起始点为接收方确认号,终止于窗口长度,只有落在窗口内的数据可以发送。 为了解决网络拥塞问题,发送方又引入了另外一个窗口,叫拥塞窗口(Congestion Window),拥塞窗口被初始化为1个报文段的长度(即另一端通知的最大报文段长度为MSS)。在建立连接时,发送方只发送一个长度为MSS的
24、报文段,正常收到确认后,拥塞窗口就增大为2MSS,即为原来拥塞窗口长度的两倍,然后发送两个MSS长度的报文段。 第第3章章 传输层协议传输层协议UDP和和TCP3.3.4 TCP的超时重发机制TCP协议提供的是可靠的运输层。前面我们已经看到,接收方对收到的所有数据要进行确认,TCP的确认是对收到的字节流进行累计确认。发送TCP报文段时,头部的“确认号”就指出该端希望接收的下一个字节的序号,其含义是在此之前的所有数据都已经正确收到,请发送从确认号开始的数据。TCP的确认方式有两种:一种是利用只有TCP头部,而没有数据区的专门确认报文段进行确认;另一种是当通信双方都有数据要传输时,把确认“捎带”在
25、要传输的报文段中进行确认,因此TCP的确认报文段和普通数据报文段没有什么区别。 第第3章章 传输层协议传输层协议UDP和和TCP在TCP协议层实现超时重发的关键问题是超时重送的策略,即怎样决定超时间隔和如何确定重发的频率。显然使用固定大小的超时间隔有很大的不足之处。 一个好的实现超时重发的方案应该是超时间隔可以随网络的通信状况而自动调整,即超时间隔应具有一定的自适应性。这种动态调整超时间隔的方法与一条连接从发送端发出数据到收到确认所需的往返时间RTT(Round Trip Time)有关。第第3章章 传输层协议传输层协议UDP和和TCP具体实现时,可以在每条连接上保持一个叫RTT的变量,发送一
26、个TCP报文段的同时启动定时器,收到确认后计算出本次的RTT值(下面用M表示),然后根据下面的公式求出新的RTT加权平均值:计算RTT:RTT=RTT+(1)M计算重发超时间隔RTO(Retransmission Time Out):RTO=RTT第第3章章 传输层协议传输层协议UDP和和TCP和都是加权因子,(01)决定本次传输的TCP报文段对往返时间RTT的影响程度。比较大时,RTT主要由历史数据确定;比较小时,RTT紧跟当时的延迟而变化。的推荐值为2,也就是说,当等待到2倍的加权平均往返时间后还没有收到确认就重发数据。取值接近1时,显然超时间隔比较短,它的优点是可以减少等待时间,但可能引
27、起一些不必要的重发;取值比较大时,可能因等待时间太长而降低了网络的通信效率。 第第3章章 传输层协议传输层协议UDP和和TCP3.4 TCP与UDP的比较下面对这两个协议进行一下比较,见表3-4。第第3章章 传输层协议传输层协议UDP和和TCP表3-4 TCP与UDP的比较 比 较 项 目 TCP UDP 建立的连接与关闭 有 无 数据传输效率(当网络可靠时) 低 高 对数据的确认 有 无 流量控制 有(滑动窗口) 无 丢失分组的重发 有 无(由高层应用程序负责) 协议复杂性 复杂 简单 发送端缓冲 有 无 分组排序 有 无 对重复分组的检测 有 无 校验和 有 有(且算法相同) 在低层被分片
28、的情况 可能性小(因为在连接建立时,双方通知各自的 MSS,每个 TCP报文段的长度不超过 MSS) 可能性大(因 为应用程 序每次 输出都产生一个 UDP 报文, 当一次有大量数据要输出时,常在低层被分片) 广播与多播 不支持(因为它要建立一对一的连接) 支持 适用场合 可靠性要求高,有大量数据要连续传输,该协议在互联网中应用较多 对可靠性要求一般,但要求高效传输数据,或应用于数据传输量小的场合 第第3章章 传输层协议传输层协议UDP和和TCP习题习题 1什么是TCP/IP协议中的端到端通信?2端口号在传输层起什么作用?3试述UDP协议的特点。4TCP协议报文段中的主要字段有哪些?5TCP通过哪些措施来保证数据的可靠性传输?6TCP是如何实现连接的建立与关闭、流量控制和超时重发的?7试述TCP和UDP的使用场合。