当前位置: 首页 > article >正文

Sa-Token v.. 发布 ,正式支持 Spring Boot 、新增 Jackson/Snack 插件适配

先回顾三次握手建立连接核心流程实际版为了让挥手流程衔接更顺畅咱们先快速回顾三次握手的实际核心避免上下文脱节第一步客户端→服务器客户端发SYN报文发起连接内核分配临时端口、创建TCB状态从CLOSED→SYN-SENT第二步服务器→客户端服务器收SYN后发SYNACK报文回应创建TCB状态从LISTEN→SYN-RCVD第三步客户端→服务器客户端收SYNACK后发ACK报文可带数据状态从SYN-SENT→ESTABLISHED服务器收ACK后状态→ESTABLISHED连接正式建立。连接建立后双方就可以愉快传输数据了。而当数据传完要关闭连接时因为TCP是“全双工通信”双方可同时发数据不能像建立连接那样简化为三次必须通过四次交互确认双方都不再发数据这就是四次挥手的由来。前置补充四次挥手的核心前提与关键概念挥手前先明确两个核心点避免理解偏差1. 全双工通信与关闭逻辑TCP是全双工协议客户端和服务器可同时发送数据。因此关闭连接时要分别确认“客户端→服务器”和“服务器→客户端”两个方向的数据流都已终止不能一次性关闭双向连接。2. 新增标记位FIN与状态挥手过程除了用到ACK标记位还会用到新的标记位FINFinish结束同时涉及几个新的TCP状态核心如下【FIN1】表示发送方已无数据要发请求关闭自己这边的数据流【FIN-WAIT-1】发送FIN后等待对方ACK的状态【CLOSE-WAIT】收到对方FIN后确认关闭请求等待自己这边数据发完再发FIN【TIME-WAIT】客户端最后发完ACK后等待2MSL报文最大生存时间确保对方收到FIN的ACK避免报文丢失导致重发。四次挥手全流程社恐式告别实际底层交互咱们依然以“手机退出微信”为例一边用通俗对话理解逻辑一边补充操作系统内核、报文交互等实际细节兼顾易懂性与技术深度。第一步主动方发起告别请求FINACK报文主动关闭场景你点击微信退出登录客户端手机作为主动关闭方告知服务器“我这边数据发完了要关连接了”。实际行为微信客户端程序调用close()接口通知内核关闭连接。客户端内核做两件事停止发送新数据将未发完的数据一次性发完然后构造FINACK报文FIN1表示关闭自身数据流ACK1确认之前收到的服务器数据序号sequu是客户端最后一次发数据的序号1确认号ackvv是服务器最后一次发数据的序号1发送报文后释放部分资源仅保留接收数据的能力防止服务器还有数据要发。拟人对话客户端温和“服务器大佬我这边数据都发完了要关我这边的连接了FIN1你之前发的内容我都收到了ACK1你还有要发的吗”状态变化客户端TCP状态从ESTABLISHED→FIN-WAIT-1开始计时等待服务器的ACK回应。第二步被动方确认告别请求ACK报文等待自身数据发完场景微信服务器收到客户端的告别请求先确认“收到了”同时继续处理自己这边未发完的数据比如最后的登录状态同步。实际行为服务器内核收到FINACK报文后校验序号、确认号无误然后构造ACK报文ACK1序号seqv确认号acku1告知客户端“你的FIN我收到了你可以不用等我回应了”发送ACK后服务器不会立即关闭连接而是继续发送自身未完成的数据此时服务器仅关闭“客户端→服务器”的数据流自身仍可向客户端发数据。拟人对话服务器沉稳“收到你的告别请求了ACK1我这边还有点数据没发完你先等我一下发完了我再告诉你。”状态变化服务器TCP状态从ESTABLISHED→CLOSE-WAIT客户端收到ACK后状态从FIN-WAIT-1→FIN-WAIT-2等待服务器发完数据后发起的FIN报文。第三步被动方发起告别请求FINACK报文被动关闭场景服务器发完所有数据告知客户端“我这边也发完了咱们可以彻底关连接了”。实际行为服务器发完剩余数据后内核构造FINACK报文FIN1表示关闭自身数据流ACK1确认之前的交互序号seqww是服务器最后一次发数据的序号1确认号acku1与第二步的ack一致因为客户端此时已无数据发送发送给客户端。拟人对话服务器完成收尾“我这边数据也发完了要关我这边的连接了FIN1你之前的消息我都收到了ACK1咱们可以告别了。”状态变化服务器TCP状态从CLOSE-WAIT→LAST-ACK开始计时等待客户端的最终ACK确认。第四步主动方最终确认告别ACK报文等待超时场景客户端收到服务器的告别请求确认双方都无数据要发给出最终回应同时等待一段时间确保服务器收到回应。实际行为客户端内核收到FINACK报文后校验无误然后构造ACK报文ACK1序号sequ1确认号ackw1告知服务器“你的FIN我收到了你可以安全关闭了”发送给服务器发送ACK后客户端不立即关闭连接而是进入TIME-WAIT状态等待2MSL通常是2分钟左右确保服务器能收到ACK若服务器没收到会重发FIN客户端可再次回应。等待超时后释放所有资源和TCB。拟人对话客户端放心“收到你的告别了ACK1我等一会儿再挂确保你能收到我的回应咱们下次见”状态变化客户端TCP状态从FIN-WAIT-2→TIME-WAIT等待2MSL→CLOSED服务器收到ACK后状态从LAST-ACK→CLOSED释放所有资源至此双向连接完全关闭。可视化流程图三次握手四次挥手全链路版结合连接建立、数据传输、连接关闭的完整链路用Mermaid图还原内核状态、报文交互全流程暂时无法在豆包文档外展示此内容关键差异与核心疑问解答1. 为啥挥手要四次握手却只要三次核心原因是“全双工通信”与“连接阶段的特殊性”三次握手时服务器的SYN同步连接和ACK确认客户端可以合并为一个SYNACK报文——因为此时服务器还没有数据要发同步和确认可以一次性完成四次挥手时服务器收到客户端的FIN后不能立即发FIN可能还有数据要发只能先回一个ACK确认等数据发完后再单独发FIN因此ACK和FIN无法合并必须分成两步导致总次数变为四次。2. TIME-WAIT状态为啥要等2MSL主要是两个目的避免连接残留问题确保服务器收到最终ACK若第四步的ACK丢失服务器会在超时后重发FIN2MSL的时间足够客户端收到重发的FIN并再次回应避免旧报文干扰新连接2MSL是报文在网络中的最大生存时间等待超时后网络中该连接的所有旧报文都会失效后续新连接用相同端口也不会被干扰。3. 常见坑点实际场景补充【CLOSE-WAIT累积】服务器处于CLOSE-WAIT状态时若应用程序未及时调用close()发FIN会导致连接资源泄露大量CLOSE-WAIT状态会耗尽服务器端口【TIME-WAIT过多】高并发场景下客户端频繁关闭连接会产生大量TIME-WAIT状态可通过调整内核参数如缩短2MSL时间、开启端口复用优化【半关闭连接】若一方发了FIN但另一方还在发数据发FIN的一方会拒绝接收数据导致数据丢失因此关闭连接前需确保双方都无数据要发。总结TCP连接的“始”与“终”核心都是“可靠”TCP三次握手与四次挥手本质都是围绕“可靠传输”设计的流程三次握手通过双向确认确保双方通信能力正常为数据传输铺路四次挥手通过分步确认确保双向数据流都已终止避免数据丢失或残留。斩壬腾蓖

相关文章:

Sa-Token v.. 发布 ,正式支持 Spring Boot 、新增 Jackson/Snack 插件适配

先回顾:三次握手(建立连接)核心流程(实际版) 为了让挥手流程衔接更顺畅,咱们先快速回顾三次握手的实际核心,避免上下文脱节: 第一步(客户端→服务器)&#xf…...

量子计算流体动力学:原理、挑战与噪声缓解策略

1. 量子计算流体动力学概述量子计算流体动力学(QCFD)是近年来兴起的前沿交叉领域,它试图利用量子计算机的独特优势来解决传统CFD方法面临的"维数灾难"问题。在经典计算机上,直接数值模拟(DNS)需要网格分辨率达到Kolmogo…...

Win11Debloat:3步彻底优化Windows系统性能与隐私设置

Win11Debloat:3步彻底优化Windows系统性能与隐私设置 【免费下载链接】Win11Debloat A simple, lightweight PowerShell script that allows you to remove pre-installed apps, disable telemetry, as well as perform various other changes to declutter and cus…...

Python自动化脚本并发控制实战

想同时处理1000个任务,却担心内存爆炸?想让下载速度翻倍,又怕被服务器封IP?本文详细介绍Python中的并发编程技术——从threading到asyncio,从进程池到协程,让你轻松掌握高并发场景下的Python自动化脚本开发。 什么时候需要并发 并发编程不是银弹,滥用反而会让代码更复…...

每日60秒读懂世界:2026年4月28日|劳动表彰、工业利润、消费回暖、新能源突破与全球局势

🔥个人主页:杨利杰YJlio❄️个人专栏:《Sysinternals实战教程》《Windows PowerShell 实战》《WINDOWS教程》《IOS教程》《微信助手》《锤子助手》 《Python》 《Kali Linux》 《那些年未解决的Windows疑难杂症》🌟 让复杂的事情更…...

NEO-F10N-00B,实现米级精度并提供安全GNSS的无线模块

简介今天我要向大家介绍的是 u-blox 的无线模块——NEO-F10N-00B。它基于 u-blox F10 双频 GNSS 技术,利用 L1/L5 频段并采用专有的双频多径抑制技术,在城市环境中能够提供可靠的米级定位精度。该模块具备卓越的射频抗干扰能力,支持安全启动、…...

Anaconda环境下的忍者像素绘卷高级调参指南

Anaconda环境下的忍者像素绘卷高级调参指南 1. 环境准备与模型部署 在开始调参之前,我们需要确保环境配置正确。Anaconda作为Python环境管理工具,能有效隔离不同项目的依赖关系。 首先通过Anaconda Navigator或命令行创建一个新的Python环境&#xff…...

别再只用CNN当判别器了!试试用U-Net给GAN做‘像素级’体检,效果提升太明显

用U-Net重构GAN判别器:实现像素级图像生成的秘密武器 在图像生成领域,我们常常陷入一个怪圈——生成器越来越复杂,但判别器却十年如一日地使用着相同的CNN架构。这就像用体温计给病人做全身CT扫描,只能给出整体"发烧与否&quo…...

PrintExp隐藏技巧:用好‘参考线’和‘墨量统计’,让你的UV打印精度与成本控制提升一个档次

PrintExp隐藏技巧:用好‘参考线’和‘墨量统计’,让你的UV打印精度与成本控制提升一个档次 在UV打印领域,精度和成本控制往往是决定项目成败的关键因素。许多用户在使用PrintExp时,仅仅停留在基础功能层面,却忽略了软件…...

你还在用 Snipe-IT?一个更好用的国产替代来了

🍊 西柚 Ciyo 资产管理系统 v0.3 更新日志 本次 v0.3 版本围绕系统核心能力与实际使用反馈进行了集中优化,重点提升了岗位逻辑、数据管理能力与系统安全性,并进一步夯实了后续扩展能力的基础。 🚀 核心更新内容 🧩 岗…...

extract-video-ppt:一站式智能视频内容提取的革命性解决方案

extract-video-ppt:一站式智能视频内容提取的革命性解决方案 【免费下载链接】extract-video-ppt extract the ppt in the video 项目地址: https://gitcode.com/gh_mirrors/ex/extract-video-ppt 在数字化学习与知识传播的时代,视频已成为信息传…...

Elasticsearch性能优化:JVM GC调优全攻略,彻底解决集群卡顿、吞吐量下降问题

Elasticsearch性能优化:JVM GC调优全攻略,彻底解决集群卡顿、吞吐量下降问题前言一、为什么 ES GC 如此关键?1.1 ES 内存结构特点1.2 GC 异常导致的生产问题1.3 ES GC 优化整体流程图二、Elasticsearch JVM GC 基础原理2.1 ES 默认 GC 算法2.…...

VLC-Qt深度解析:Qt应用中的专业视频播放方案

Qt自带的QMediaPlayer不够用?深入VLC-Qt源码,解锁专业级视频播放的全部能力 一、VLC-Qt概述 VLC-Qt是libVLC的Qt封装库,将强大的VLC播放引擎集成到Qt应用中。相比Qt原生QMediaPlayer,VLC-Qt提供了更强大的解码能力和更丰富的控制…...

别只用来关梯度了!torch.no_grad()的3个隐藏用法与常见误区盘点

别只用来关梯度了!torch.no_grad()的3个隐藏用法与常见误区盘点 在PyTorch的日常使用中,torch.no_grad()可能是最容易被低估的上下文管理器之一。大多数开发者仅仅把它当作关闭梯度计算的开关,却不知道这个简单的工具背后隐藏着诸多高级用法和…...

数据结构——栈和队列的相互模拟

栈:只能一端进行插入和删除,具有先进后出的特点队列:一端进行插入一端进行删除,具有先进先出的特点1.两个栈来模拟一个队列:此时我们将第一个栈称为S1,将第二个栈称为S2。思路:入队:…...

IT疑难杂症诊疗室:快速解决技术难题

以下是一篇关于“IT疑难杂症诊疗室”的技术文章大纲。该大纲旨在帮助读者系统性地诊断和解决IT常见问题,内容结构清晰,分为引言、问题分类、诊断方法、解决方案、预防措施和结论等部分。大纲设计基于真实IT支持经验,确保实用性和可操作性。1.…...

2026年最后的内存池升级窗口期已开启!错过本次,你的订单匹配引擎将无法通过中证协FPGA协同验证

更多请点击: https://intelliparadigm.com 第一章:2026年中证协FPGA协同验证对内存池的硬性技术要求 为满足中证协《2026年证券期货行业FPGA加速验证规范(V3.2)》强制条款,FPGA协同验证平台中的内存池必须在硬件抽象层…...

KMS_VL_ALL_AIO:3分钟彻底解决Windows和Office激活难题的终极方案

KMS_VL_ALL_AIO:3分钟彻底解决Windows和Office激活难题的终极方案 【免费下载链接】KMS_VL_ALL_AIO Smart Activation Script 项目地址: https://gitcode.com/gh_mirrors/km/KMS_VL_ALL_AIO 还在为Windows系统频繁弹出激活提示而烦恼吗?Office文档…...

车载Java微服务架构崩塌前夜:当Android Automotive与QNX Hypervisor共存时,你必须立即重构的4个IPC通信层

更多请点击: https://intelliparadigm.com 第一章:车载Java微服务架构崩塌前夜:当Android Automotive与QNX Hypervisor共存时,你必须立即重构的4个IPC通信层 在混合车载操作系统环境中,Android Automotive&#xff0…...

【信创验收倒计时】:Java系统通过等保2.0+国密SM2/SM4+中间件适配的9项必检清单

更多请点击: https://intelliparadigm.com 第一章:信创验收背景与Java系统国产化适配总体要求 在国家信息技术应用创新战略持续深化的背景下,信创项目验收已从“能用”全面转向“好用、安全、可控”。Java 系统作为政务、金融、能源等关键领…...

为什么你的Docker AI沙箱无法通过等保2.0三级认证?4类强制隔离缺口+3份可审计的auditd策略模板

更多请点击: https://intelliparadigm.com 第一章:Docker Sandbox 运行 AI 代码隔离技术 性能调优指南 Docker Sandbox 为 AI 模型推理与训练脚本提供了轻量级、可复现的隔离环境,但默认配置常导致 GPU 利用率偏低、内存抖动明显或 I/O 瓶颈…...

告别‘炼丹’低效!手把手教你用TinyViT的‘稀疏软标签’实现快速模型蒸馏

突破计算瓶颈:TinyViT稀疏软标签蒸馏实战指南 在模型压缩领域,知识蒸馏一直是个让人又爱又恨的技术。它能将大模型的知识精华提炼给小模型,但传统方法需要反复调用庞大的教师模型,这种"炼丹"过程不仅耗时耗力&#xff0…...

Stata实战:用estat vif和collin命令搞定多重共线性诊断(附完整代码)

Stata实战:多重共线性诊断的完整解决方案与深度解析 在实证研究过程中,我们常常会遇到一个令人头疼的问题——模型结果看起来不错,但某些自变量的系数符号与理论预期相反,或者统计显著性忽高忽低。这很可能就是多重共线性在作祟。…...

3个超实用技巧:让Mem Reduct内存清理工具完美适配中文环境

3个超实用技巧:让Mem Reduct内存清理工具完美适配中文环境 【免费下载链接】memreduct Lightweight real-time memory management application to monitor and clean system memory on your computer. 项目地址: https://gitcode.com/gh_mirrors/me/memreduct …...

AIGC工具平台-LessonPPTCapCut课件制作

课程制作常需要反复准备模板、素材和剪映草稿目录,手工整理流程繁琐,也容易出现路径和模板错误。 LessonPPTCapCut 用于根据课程信息和模板生成课件结果或剪映草稿,支持配置管理、模板选择、课件制作和运行日志。 文章目录模块定位项目配置项…...

别再租GPU烧钱了!用Colab免费GPU+公开数据集,30分钟跑通YOLOv8商品识别模型

零成本玩转YOLOv8:Colab免费GPU公开数据集实战商品识别 在计算机视觉领域,YOLOv8作为目标检测的标杆算法,其应用场景早已从安防监控延伸到零售行业。想象一下,当你走进一家无人便利店,摄像头瞬间识别出你手中的商品并自…...

程序员技术成长路线图(2024版)

程序员技术成长路线图(2024版):技术浪潮下的进阶指南 在技术迭代加速的2024年,程序员如何规划成长路径?《程序员技术成长路线图(2024版)》结合行业趋势,为开发者提供了一份清晰的进…...

2026年热门做会议纪要神器app深度测评,翻车了大半网红款,黑马拉开的差距竟然这么大

我帮医疗圈和律所的朋友测了一圈2026年热门的会议纪要转写APP,踩了大半网红款的坑,对比下来,听脑AI是同类工具中最值得用的,尤其是对专业度、隐私性、转写效率要求高的医疗、法律从业者,听脑AI作为黑马拉开的差距比我预…...

2026年热门会议记录语音转文字工具实测对比,准确率比拼差距竟然这么大,真香款才是隐藏王者

对比了多款2026年热门的语音转文字工具,针对医疗、法律从业者最关心的专业术语识别、隐私保护、长录音处理三个核心维度实测完,听脑AI是综合体验最好的,也是目前同类工具中最值得推荐给专业从业者的选择。 直达链接:https://itin…...

vSAN维护模式选‘无操作’就万事大吉?详解关机重启前必须做的5项关键检查

vSAN维护模式选‘无操作’就万事大吉?详解关机重启前必须做的5项关键检查 在虚拟化运维领域,vSAN集群的关机重启操作看似简单,实则暗藏玄机。许多工程师习惯性地选择维护模式中的"无操作"选项,认为这样可以省去数据迁移…...