1.TCP数据段格式

  TCP是一种可靠的、面向连接的字节流服务。源主机在传送数据前需要先和目标主机建立连接。然后,在此连接上,被编号的数据段按序收发。同时,要求对每个数据段进行确认,保证了可靠性。如果在指定的时间内没有收到目标主机对所发数据段的确认,源主机将再次发送该数据段。

如图所示,是TCP头部结构

 

  

  源、目标端口号字段:占16比特。TCP协议通过使用"端口"来标识源端和目标端的应用进程。端口号可以使用065535之间的任何数字。在收到服务请求时,操作系统动态地为客户端的应用程序分配端口号。在服务器端,每种服务在"众所周知的端口"Well-Know Port)为用户提供服务。


  顺序号字段:占32比特。用来标识从TCP源端向TCP目标端发送的数据字节流,它表示在这个报文段中的第一个数据字节。


  确认号字段:占32比特。只有ACK标志为1时,确认号字段才有效。它包含目标端所期望收到源端的下一个数据字节。


  头部长度字段:占4比特。给出头部占32比特的数目。没有任何选项字段的TCP头部长度为20字节;最多可以有60字节的TCP头部。


        ● 标志位字段( U A P R S F ):占 6 比特。各比特的含义如下:


        ◆ URG :紧急指针( urgent pointer )有效。


        ◆ ACK :确认序号有效。


        ◆ PSH :接收方应该尽快将这个报文段交给应用层。


        ◆ RST :重建连接。


        SYN :发起一个连接。


        FIN :释放一个连接。


  窗口大小字段:占16比特。此字段用来进行流量控制。单位为字节数,这个值是本机期望一次接收的字节数。


  ●TCP校验和字段:占16比特。对整个TCP报文段,即TCP头部和TCP数据进行校验和计算,并由目标端进行验证。

  紧急指针字段:占16比特。它是一个偏移量,和序号字段中的值相加表示紧急数据最后一个字节的序号。

  选项字段:占32比特。可能包括"窗口扩大因子""时间戳"等选项。


  2UDP数据段格式


  UDP是一种不可靠的、无连接的数据报服务。源主机在传送数据前不需要和目标主机建立连接。数据被冠以源、目标端口号等UDP报头字段后直接发往目的主机。这时,每个数据段的可靠性依靠上层协议来保证。在传送数据较少、较小的情况下,UDPTCP更加高效。


  如图所示,是UDP头部结构

 

  源、目标端口号字段:占16比特。作用与TCP数据段中的端口号字段相同,用来标识源端和目标端的应用进程。


  长度字段:占16比特。标明UDP头部和UDP数据的总长度字节。


  校验和字段:占16比特。用来对UDP头部和UDP数据进行校验。和TCP不同的是,对UDP来说,此字段是可选项,而TCP数据段中的校验和字段是必须有的。


  套接字


  在每个TCPUDP数据段中都包含源端口和目标端口字段。有时,我们把一个IP地址和一个端口号合称为一个套接字(Socket),而一个套接字对(Socket pair)可以唯一地确定互连网络中每个TCP连接的双方(客户IP地址、客户端口号、服务器IP地址、服务器端口号)。

需要注意的是,不同的应用层协议可能基于不同的传输层协议,如FTPTELNETSMTP协议基于可靠的TCP协议。TFTPSNMPRIP基于不可靠的UDP协议。

同时,有些应用层协议占用了两个不同的端口号,如FTP2021端口,SNMP161162端口。这些应用层协议在不同的端口提供不同的功能。如FTP21端口用来侦听用户的连接请求,而20端口用来传送用户的文件数据。再如,SNMP161端口用于SNMP管理进程获取SNMP代理的数据,而162端口用于SNMP代理主动向SNMP管理进程发送数据。

还有一些协议使用了传输层的不同协议提供的服务。如DNS协议同时使用了TCP 53端口和UDP 53端口。DNS协议在UDP53端口提供域名解析服务,在TCP53端口提供DNS区域文件传输服务。

TCP连接建立、释放时的握手过程


 1TCP建立连接的三次握手过程

TCP会话通过三次握手来初始化。三次握手的目标是使数据段的发送和接收同步。同时也向其他主机表明其一次可接收的数据量(窗口大小),并建立逻辑连接。这三次握手的过程可以简述如下:

 源主机发送一个同步标志位(SYN)置1TCP数据段。此段中同时标明初始序号(Initial Sequence NumberISN)。ISN是一个随时间变化的随机值。

目标主机发回确认数据段,此段中的同步标志位(SYN)同样被置1,且确认标志位(ACK)也置1,同时在确认序号字段表明目标主机期待收到源主机下一个数据段的序号(即表明前一个数据段已收到并且没有错误)。此外,此段中还包含目标主机的段初始序号。

 源主机再回送一个数据段,同样带有递增的发送序号和确认序号。

至此为止,TCP会话的三次握手完成。接下来,源主机和目标主机可以互相收发数据。整个过程可用图表示。

    

    TCP建立连接的三次握手过程