一、了解TCP报文段
Seq:序列号,占32位,用来标识从TCP源端向目的端发送的字节流,发起方发送数据时对此进行标记。
ACK(Acknowledgement):确认序号位,当该为1时,用于确认发送方的数据
窗口大小:用于说明本地可接收数据段的数目,窗口大小是可变的
SYN:同步序列号,TCP需要建立连接时将该值设为1
FIN:当TCP断开连接时将该位置为1
ACK(Acknowledgement Number):确认序号,占32位,只有ACK标志位为1时,确认序号字段才有效,Ack=Seq+1
其他的可以参考:https://blog.csdn.net/mary19920410/article/details/58030147
二、TCP/IP三次握手
图片中名词的解释:
CLOSED 初始(无连接)状态。
LISTEN 侦听状态,等待远程机器的连接请求。
SYN_SEND 在TCP三次握手中,主动连接端发送了SYN包后,进入SYN_SEND状态,等待对方的ACK包。
SYN_RECV 在TCP三次握手中,主动连接端收到ACK包后,进入SYN_RECV状态。
ESTABLISHED 完成TCP三次握手后,主动连接端进入ESTABLISHED状态。此时,TCP连接已经建立,可以进行通信。
TCP三次握手的过程如下:
1. 客户机1(主动连接端)发送一个SYN包给服务器2(被动连接端);
2. 服务器2(被动连接端)收到SYN包后,发送一个带ACK和SYN标志的包给客户机1(主动连接端);
3. 客户机1(主动连接端)发送一个带ACK标志的包给服务器2(被动连接端),握手动作完成。
三、TCP/IP四次挥手
图片中名词的解释:
FIN_WAIT_1 在TCP四次断开时,主动关闭端发送FIN包后,进入FIN_WAIT_1状态。
FIN_WAIT_2 在TCP四次断开时,主动关闭端收到ACK包后,进入FIN_WAIT_2状态。
TIME_WAIT 在TCP四次断开时,主动关闭端发送了ACK包之后,进入TIME_WAIT状态。
CLOSE_WAIT 在TCP四次断开时,被动关闭端收到FIN包后,进入CLOSE_WAIT状态。
LAST_ACK 在TCP四次断开时,被动关闭端发送FIN包后,进入LAST_ACK状态,等待对方的ACK包。
TCP四次断开的过程如下:
1. 客户机1(主动连接端)发送一个FIN包给服务器2(被动连接端)请求断开连接;
2. 服务器2(被动连接端)收到FIN包后,发送一个ACK包给客户机1(主动连接端);
3. 服务器2(被动连接端)发送了ACK包后,再发送一个FIN包给客户机1(主动连接端)确认断开;
4. 客户机1(主动连接端)收到FIN包后,发送一个ACK包,当服务器2(被动连接端)收到ACK包后,四次断开动作完 成,连接断开。