本文来源于以前摘录的 但是已不知何处!
三次握手 四次挥手
三次握手即tcp连接的建立,一个tcp连接可以发送多个http请求
1、第一次握手
·······客户端向 服务器端发送tcp报文
SYN= 1 表示请求建立连接
seq=x (x一般为1)
客户端进入 SYN_SENT状态
2、第二次握手
服务器接收到客户端的tcp报文,结束listen阶段,返回一段http报文
SYN=1
ACK=1
seq=y
ack = x+1 表示收到客户的序号seq序号有效,表示收到客户端的序号Seq并将其值加1作为自己确认号Ack的值;随后服务器端进入SYN_RCVD阶段
3、第三次握手
客户端接收到服务器的返回报文,明确客户端到服务器端是可以传输的,结束 SYN_SENT,并发送最后一段 报文。
标志位为ACK,表示“确认收到服务器端同意连接的信号”(即告诉服务器,我知道你收到我发的数据了);
序号为Seq=x+1,表示收到服务器端的确认号Ack,并将其值作为自己的序号值
确认号为Ack=y+1,表示收到服务器端序号Seq,并将其值加1作为自己的确认号Ack的值;
随后客户端进入ESTABLISHED阶段。
服务器收到来自客户端的“确认收到服务器数据”的TCP报文之后,明确了从服务器到客户端的数据传输是正常的。结束SYN_RCVD阶段,进入ESTABLISHED阶段。
四次挥手
1、客户端想要释放连接,向服务端发送一段报文
标记为FIN 表示请求释放连接
序号为Seq = U
随后客户端进入FIN-WAIT-1阶段,即半关闭阶段。并且停止在客户端到服务器端方向上发送数据,但是客户端仍然能接收从服务器端传输过来的数据
注意:这里不发送的是正常连接时传输的数据(非确认报文),而不是一切数据,所以客户端仍然能发送ACK确认报文。
2、服务器接收到客户端的报文 服务端结束ESTABLISHED,进入CLOSE_WAIT
办关闭状态
标记为ACK
序号为Seq=V
确认好为Ack = U+1表示是在收到客户端报文的基础上,将其序号Seq值加1作为本段报文确认号Ack的值
随后服务器端开始准备释放服务器端到客户端方向上的连接。客户端收到从服务器端发出的TCP报文之后,确认了服务器收到了客户端发出的释放连接请求,随后客户端结束FIN-WAIT-1阶段,进入FIN-WAIT-2阶段
3、服务器端自从发出ACK确认报文之后,经过CLOSED-WAIT阶段,做好了释放服务器端到客户端方向上的连接准备,再次向客户端发出一段TCP报文
标记位为FIN,ACK,表示“已经准备好释放连接了”。注意:这里的ACK并不是确认收到服务器端报文的确认报文
Seq = w
Ack = U+1
确认号为Ack=U+1;表示是在收到客户端报文的基础上,将其序号Seq值加1作为本段报文确认号Ack的值。随后服务器端结束CLOSE-WAIT阶段,进入LAST-ACK阶段。并且停止在服务器端到客户端的方向上发送数据,但是服务器端仍然能够接收从客户端传输过来的数据。
4、
客户端收到从服务器端发出的TCP报文,确认了服务器端已做好释放连接的准备,结束FIN-WAIT-2阶段,进入TIME-WAIT阶段,并向服务器端发送一段报文,其中:
标记位为ACK,表示“接收到服务器准备好释放连接的信号”。序号为Seq=U+1;表示是在收到了服务器端报文的基础上,将其确认号Ack值作为本段报文序号的值。确认号为Ack=W+1;表示是在收到了服务器端报文的基础上,将其序号Seq值作为本段报文确认号的值。