TCP四次挥手过程

TCP 断开连接是通过四次挥手方式。

双方都可以主动断开连接,断开连接后主机中的「资源」将被释放,

刚开始双方都处于 establised 状态,假如是客户端先发起关闭请求,过程如下图:

第一次挥手:客户端打算关闭连接,此时会发送一个 TCP 首部 FIN 标志位被置为 1 的报文,也即 FIN 报文,之后客户端进入 FIN_WAIT_1 状态。

第二次挥手:服务端收到该报文后,就向客户端发送 ACK 应答报文,且把客户端的序列号值 + 1 作为 ACK 报文的序列号值,表明已经收到客户端的报文了,接着服务端进入 CLOSE_WAIT 状态。

第三次挥手:如果服务端也想断开连接了,等待服务端处理完数据后,和客户端的第一次挥手一样,发给 FIN 报文,且指定一个序列号。此时服务端处于 LAST_ACK 的状态。

客户端收到服务端的 ACK 应答报文后,之后进入 FIN_WAIT_2 状态。

第四次挥手:客户端收到服务端的 FIN 报文后,回一个 ACK 应答报文,且把服务端的序列号值 + 1 作为自己 ACK 报文的序列号值,之后客户端进入 TIME_WAIT 状态

服务端收到了 ACK 应答报文后,就进入了 CLOSE 状态,至此服务端已经完成连接的关闭。

客户端在经过 2MSL 一段时间后,自动进入 CLOSE 状态,至此客户端也完成连接的关闭。

你可以看到,每个方向都需要一个 FIN 和一个 ACK ,因此通常被称为四次挥手

这里一点需要注意是:主动关闭连接的,才有 TIME_WAIT 状态。

此外,这里我给出每个状态所包含的含义。

LISTEN -- 侦听来自远方TCP端口的连接请求;

SYN-SENT - 在发送连接请求后等待匹配的连接请求;

SYN_RECEIVED -- 在收到和发送一个连接请求后等待对连接请求的确认;

ESTABLISHED - 代表一个打开的连接,数据可以传送给用户;

FIN_WAIT_1 -- 等待远程TCP的连接中断请求,或先前的连接中断请求的确认;

FIN_WAIT_2 -- 从远程TCP等待连接中断请求;

CLOSE_WAIT -- 等待从本地用户发来的连接中断请求;

CLOSING -等待远程TCP对连接中断的确认;

LAST_ACK -- 等待原来发向远程TCP的连接中断请求的确认;

TIME_WAIT -等待足够的时间以确保远程TCP接收到连接中断请求的确认;

CLOSED -- 没有任何连接状态;

相关推荐
tang777892 小时前
一张图看懂 HTTP、SOCKS5 代理的区别
网络·网络协议·http
枷锁—sha4 小时前
【CTFshow-pwn系列】03_栈溢出【pwn 045】详解:Ret2Libc 之 32位动态泄露(补充本地 Libc 手动加载指南)
服务器·网络·网络安全·系统安全
liann1195 小时前
4.3.2_WEB——WEB后端语言——PHP
开发语言·前端·网络·安全·web安全·网络安全·php
byzh_rc5 小时前
[深度学习网络从入门到入土] 含并行连结的网络GoogLeNet
网络·人工智能·深度学习
乾元5 小时前
对抗性攻击:一张贴纸如何让自动驾驶视觉系统失效?
运维·网络·人工智能·安全·机器学习·自动驾驶
全栈前端老曹6 小时前
【Redis】Pipeline 与性能优化——批量命令处理、提升吞吐量、减少网络延迟
前端·网络·数据库·redis·缓存·性能优化·全栈
MediaTea8 小时前
Python:生成器对象的扩展接口
开发语言·网络·python
正儿八经的少年9 小时前
服务网关(Service Gateway)
运维·网络
末日汐10 小时前
应用层自定义协议与序列化
运维·服务器·网络
实时数据10 小时前
渗透测试步骤 信息收集:收集目标系统的相关信息,例如域名、IP地址、开放端口和服务等
网络·安全·web安全