TCP
连接是通过三次握手进行初始化的。三次握手的目的是同步连接双方的序列号和确认号并交换
TCP
窗口大小信息。以下步骤概述了通常情况下客户端计算机联系服务器计算机的过程:
1.
客户端向服务器发送一个
SYN
置位的
TCP
报文,其中包含连接的初始序列号
x
和一个窗口大小(表示客户端上用来存储从服务器发送来的传入段的缓冲区的大小)。
2.
服务器收到客户端发送过来的
SYN
报文后,向客户端发送一个
SYN
和
ACK
都置位的
TCP
报文,其中包含它选择的初始序列号
y
、对客户端的序列号的确认
x+1
和一个窗口大小(表示服务器上用来存储从客户端发送来的传入段的缓冲区的大小)。
3.
客户端接收到服务器端返回的
SYN+ACK
报文后,向服务器端返回一个确认号
y+1
和序号
x+1
的
ACK
报文,一个标准的
TCP
连接完成。
TCP
使用类似的握手过程来结束连接。这可确保两个主机均能完成传输并确保所有的数据均得以接收
TCP Client
|
Flags
|
TCP Server
|
1 Send SYN (seq=x)
|
----SYN--->
|
SYN Received
|
2 SYN/ACK Received
|
<---SYN/ACK----
|
Send SYN (seq=y)
,
ACK (x+1)
|
3 Send ACK (y+1)
|
----ACK--->
| |
x: ISN (Initial Sequence Number) of the Client
| ||
y: ISN of the Server
|
第一次是客户端发起连接;第二次表示服务器收到了客户端的请求;第三次表示客户端收到了服务器的反馈。这之后双方均确认了连接的有效性,如果第三次服务器未收到,假设一个C向S发送了SYN后无故消失了,那么S在发出SYN+ACK应答报文后是无法收到C的ACK报文的(第三次握手无法完成),这种情况下S一般会重试(再次发送SYN+ACK给客户端)并等待一段时间后丢弃这个未完成的连接,这段时间的长度我们称为SYN Timeout,一般来说这个时间是分钟的数量级(大约为30秒-2分钟);