TCP传输

TCP connection

客户端和服务端之间数据的发送和返回的过程当中需要创建一个叫TCP connection的东西。TCP不存在连接的概念,只存在请求和响应,请求和响应都是数据包,他们之间都是经过由TCP创建的一个从客户端发起,服务器接收的类似连接的通道,这个连接可以一直保持,http请求是在这个连接的基础上发送的。

 

重要的字段说明:

序号(sequence number):Seq序号,占32位,用来标识从TCP源端向目的端发送的字节流,发送方发送数据时对此进行标记

确认号(acknowledgement number):Ack序号,占32位,只有ACK标志位为1时,确认序号字段才有效,Ack=Seq + 1

标志位(Flags):共6个,即URG(紧急指针urgent pointer有效)、ACK(确认序号有效)、PSH(接收方应该尽快将这个报文交给应用层)、RST(重置连接)、SYN(发起一个新连接)、FIN(释放一个连接)

 

TCP的三次握手

握手之前主动打开连接的客户端结束CLOSED阶段,被动打开的服务器端也结束CLOSED阶段,并进入LISTEN阶段。随后开始“三次握手”:

(1)首先客户端向服务器端发送一段TCP报文,其中:标记位为SYN,表示“请求建立新连接”;序号为Seq=X(X一般为1);随后客户端进入SYN-SENT阶段。

(2)服务器端接收到来自客户端的TCP报文之后,结束LISTEN阶段。并返回一段TCP报文,其中:标志位为SYN和ACK,表示“确认客户端的报文Seq序号有效,服务器能正常接收客户端发送的数据,并同意创建新连接”(即告诉客户端,服务器收到了你的数据);序号为Seq=y;确认号为Ack=x+1,表示收到客户端的序号Seq并将其值加1作为自己确认号Ack的值;随后服务器端进入SYN-RCVD阶段。

(3)客户端接收到来自服务器端的确认收到数据的TCP报文之后,明确了从客户端到服务器的数据传输是正常的,结束SYN-SENT阶段。并返回最后一段TCP报文。其中:标志位为ACK,表示“确认收到服务器端同意连接的信号”(即告诉服务器,我知道你收到我发的数据了);序号为Seq=x+1,表示收到服务器端的确认号Ack,并将其值作为自己的序号值;确认号为Ack=y+1,表示收到服务器端序号Seq,并将其值加1作为自己的确认号Ack的值;随后客户端进入ESTABLISHED阶段。服务器收到来自客户端的“确认收到服务器数据”的TCP报文之后,明确了从服务器到客户端的数据传输是正常的。结束SYN-SENT阶段,进入ESTABLISHED阶段。

在客户端与服务器端传输的TCP报文中,双方的确认号Ack和序号Seq的值,都是在彼此Ack和Seq值的基础上进行计算的,这样做保证了TCP报文传输的连贯性。一旦出现某一方发出的TCP报文丢失,便无法继续"握手",以此确保了"三次握手"的顺利完成。

此后客户端和服务器端进行正常的数据传输。这就是“三次握手”的过程。

 

具体如下:

 

TCP的四次挥手

四次挥手即TCP连接的释放(解除),连接的释放必须是一方主动释放,另一方被动释放

 

为何建立连接时需要3次,而释放连接时却要4次,即FIN释放连接报文与ACK确认接收报文要分开传输?

释放连接时,被动方服务器,突然收到主动方客户端释放连接的请求时并不能立即释放连接,因为还有必要的数据需要处理,所以服务器先返回ACK确认收到报文,经过CLOSE-WAIT阶段准备好释放连接之后,才能返回FIN释放连接报文。

 

 

参考文档:https://baijiahao.baidu.com/s?id=1654225744653405133&wfr=spider&for=pc

 

posted @ 2020-08-25 16:36  linma  阅读(242)  评论(0)    收藏  举报