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

第十八篇技术笔记:三次握手、四次挥手——郭靖与蓉儿的“信令之约”

写在开篇话说襄阳城头雪还没化完。郭靖站在城墙上望着南方心里惦念着桃花岛上的黄蓉。蒙古大军压境他已经三个月没收到黄蓉的消息了。他想写封信给蓉儿表达思念之情。用的是镖局押镖TCP——每封信都要签收确认保证送到。可这都半个月了信使还没回来。郭靖心里犯嘀咕信到底送到了没有蓉儿收到信了吗她怎么不回还是路上出了差池他找来镖局的总镖头问了个明白。总镖头捋着胡子说“郭大侠莫急。咱们镖局送信有个规矩——三步确认。走完这三步信才算真正送出去。”郭靖一愣“哪三步”总镖头倒竖个大拇指叹了口气“郭大侠您学的真烂。不知道TCP的三次握手吗”郭靖挠挠头“啥是TCP”总镖头差点一口老血喷出来。“得从头讲吧。”一、镖局和飞鸽到底管哪段路TCP/UDP是干啥的总镖头清了清嗓子“您想给蓉儿送信有两种法子。”第一种镖局押镖TCP镖局接单后不是直接上路。得先确认蓉儿在不在岛上、愿不愿意收信。确认完了才正式启程。每封信都要签收确认丢了重送保证完整送到。可靠但慢。第二种飞鸽传书UDP信绑鸽子腿上放飞。鸽子飞出去就不管了能不能到看缘分。三天能到也可能被鹰叼了。快但不可靠。郭靖想了想“蓉儿的信可不能丢。我选镖局。”总镖头点头“那您就得搞懂TCP。”二、一封完整的信包了好几层MAC头→IP头→TCP头总镖头拿出一封完整的信摊在桌上“您看一封信不是光写内容就完事的。它得包好几层。”┌─────────────────────────────────────────────────────────────────────────────┐ │ 第一层信封MAC头 │ │ ┌─────────────────────────────────────────────────────────────────────────┐│ │ │ 目标MAC收件人桃花岛源MAC寄件人襄阳镖局 ││ │ │ 这是数据链路层的活儿——在同一段路上从镖局送到驿站。 ││ │ └─────────────────────────────────────────────────────────────────────────┘│ │ ┌─────────────────────────────────────────────────────────────────────────┐│ │ │ 第二层路单IP头 ││ │ │ 目标IP桃花岛源IP襄阳城 ││ │ │ 这是网络层的活儿——从襄阳城跨城送到桃花岛中间经过多个驿站。 ││ │ └─────────────────────────────────────────────────────────────────────────┘│ │ ┌─────────────────────────────────────────────────────────────────────────┐│ │ │ 第三层押镖单TCP头 ││ │ │ 这是传输层的活儿——镖局自己的“内部单据”管签收、管顺序、管重传。 ││ │ └─────────────────────────────────────────────────────────────────────────┘│ │ ┌─────────────────────────────────────────────────────────────────────────┐│ │ │ 第四层信的内容数据 ││ │ │ “蓉儿想你了你的靖哥哥” ││ │ └─────────────────────────────────────────────────────────────────────────┘│ └─────────────────────────────────────────────────────────────────────────────┘“前面几层MAC头、IP头是‘公共路段’用的所有镖局都一样。咱们镖局自己的规矩全写在TCP头里。”三、镖局的“押镖单”长什么样TCP头按传输顺序总镖头掏出那张押镖单摊在桌上“您看这就是镖局每趟镖的‘单据’——TCP头。20个字节一行排开。”| 源端口 | 目标端口 | 序号(SEQ) | 确认号(ACK) | 头长 |标志位| 窗口 | 校验和 | |--------|--------|----------|----------- |-----|------- |-- |-------| | 16位 | 16位 | 32位 | 32位 | 4位 |12位| 16位 | 16位 |“这个标志位是整张单子的灵魂。”总镖头指着中间那12位的字段“这12位里前4位是‘头长度’的补充中间8位才是真正的标志位。您看就是这8位。”四、八道密语押镖单上的灵魂标记展开说总镖头又掏出一张图指着上面的8个标志位“您看TCP头里常用的标志位有8个狭义常用6个广义8个各管各的。”┌─────────────────────────────────────────────────────────────────────────────┐ │ TCP标志位8位有效 │ ├─────────────────────┬─────────────────────────────────────────────────────┤ │ CWR │ ECE │URG │ ACK │ PSH │ RST │ SYN │ FIN│ │ 拥塞 │ 拥塞 │ 紧急 │ 确认 │ 推 │ 重置 │ 同步 │ 结束 │ │ 1位 │ 1位 │ 1位 │ 1位 │ 1位 │ 1位 │ 1位 │ 1位 │ └─────────────────────┴─────────────────────────────────────────────────────┘先记这6个最常用的标志位全称干啥的郭靖版理解SYNSynchronize请求建立连接同步初始序号“我要发信了这是我信的第一页编号”ACKAcknowledgment确认收到了对方的包“收到了这是我回的确认”FINFinish请求断开连接“信送完了我要挂线了”RSTReset强制中断连接出错时用“出错了重来”PSHPush立即推送数据不缓存“别等了这封信马上给蓉儿”URGUrgent紧急数据插队处理“大事不好这封信插队”另外2个CWR、ECE跟拥塞控制有关郭靖问它们干啥的总镖头摆摆手“那是‘抗拥堵策略’您先把三步确认搞明白后面单独开一篇讲不然脑子该炸了。”PSH和URG的区别URG是在数据流里挖个洞塞进紧急数据PSH是催发送方别磨叽、赶紧发。车上URG基本不用PSH偶尔用。RST是啥郭靖发了个SYN但蓉儿不想理他端口没开就回一个RST“别发了我不收”或者连接过程中出了错蓉儿直接RST“出问题了重头再来。”车上RST场景诊断仪给一个不存在的ECU发连接请求网关直接回RST。五、为啥要“握手”——不打招呼就发会怎样郭靖问“为啥不能直接发”总镖头反问“您想啊蓉儿可能在睡觉可能不在岛上。您直接发信过去没人收信丢了算谁的”“所以镖局的规矩是先确认对方在不在、愿不愿意收再发。”“车上一模一样。诊断仪要升级ECU不能直接发数据——得先问ECU‘你在吗能升级吗’ECU回复‘在的准备好了。’诊断仪说‘好那我开始发了。’”“这个确认过程就是三次握手。”六、三次握手镖局的三步确认帧级别的变化总镖头掏出三张押镖单一张一张摆出来。第一步郭靖 → 黄蓉SYN镖局先派一个探子骑快马赶往桃花岛。探子到了岛门口递上第一张押镖单字段值含义SYN1“我要建立连接”ACK0第一次还没收到过确认SEQx100随机初始序号防攻击数据空不带实际信件MAC头目标MAC桃花岛源MAC襄阳镖局第一层IP头目标IP桃花岛源IP襄阳城第二层郭靖问“为啥不带信”总镖头说“防坏人。如果第一次就带大数据坏人可以狂发这种包把服务器撑爆。所以前两次只确认状态不发数据。”第二步黄蓉 → 郭靖SYNACK黄蓉听到喊声心里一喜。她也递出一张押镖单字段值含义SYN1“我也要建立连接”ACK1“我收到了你的请求”SEQy300她回信的起始序号ACK序号x1101“我期待你下一封信编号101”数据空还是不带信郭靖问“这一步能合在一起发”总镖头点头“能。‘收到了’和‘我也要发’可以同时说省一趟来回。”第三步郭靖 → 黄蓉ACK 可带数据探子把黄蓉的回信带回襄阳。郭靖看了递出第三张押镖单字段值含义SYN0连接已建立不再同步ACK1“确认收到你的回复”SEQx1101“这是你期待的第101号信”ACK序号y1301“我期待你下一封回信编号301”数据“蓉儿想你了你的靖哥哥”可以开始带实际信件了郭靖眼睛一亮“这一步就能带信了”总镖头说“对。前两步确认好了第三步直接发信省一次往返。”七、两次握手为什么不行半吊子连接郭靖问“为啥非得三步两步不行吗”总镖头叹了口气“您想过没有如果只走两步——您喊一声‘我要发信’SYN我回一声‘收到了’ACK——然后您就开始发信。但万一您那声‘我要发信’是半年前发出来、被大雪堵在路上、现在才到的幽灵信呢”郭靖一愣“您的意思是……”“那我就会以为您又要发新信傻乎乎等着您发数据您那边却根本不知道这事。白等浪费人力和仓库。”“所以第三步‘我收到了你的确认’是必需的——它告诉对方‘这个连接是我现在发起的不是过期的。’”八、四次挥手信送完了怎么“道别”信送完了郭靖要跟黄蓉说拜拜。总镖头又掏出四张道别单。第一步郭靖 → 黄蓉FIN字段值含义FIN1“我没有数据要发了”SEQu当前序号第二步黄蓉 → 郭靖ACK字段值含义ACK1“收到了你的道别请求”ACK序号u1确认收到第三步黄蓉 → 郭靖FIN字段值含义FIN1“我也没有数据要发了”SEQw当前序号第四步郭靖 → 黄蓉ACK字段值含义ACK1“确认收到你的道别”ACK序号w1确认收到郭靖问“为啥四步不能合并成三步吗”总镖头说“您说‘我要挂了’FIN我只能先回‘知道了’ACK但不能马上说‘我也挂了’——因为我可能还有话没说完得先把话说完才能说‘我也挂了’FIN。”“所以咱俩的‘再见’不能合并得分开说。”九、车上哪里用到三次握手DoIP诊断升级4S店技师把诊断仪插到OBD口诊断仪给ECU发SYNSEQ12345“我要升级你了准备好了吗”ECU回SYNACKSEQ67890, ACK12346“准备好了你发吧。”诊断仪回ACKSEQ12346, ACK67891同时开始发升级包正式传输升级数据几兆到几百兆传完后四次挥手断开连接十、这些坑我替你先踩了坑1以为“握手是发三次数据”。后来才搞明白握手阶段前两次不带数据第三次可以带。坑2以为“ACK序号就是对方SEQ加1”。后来才搞明白ACK序号 对方SEQ 对方携带的数据长度。SYN和FIN算1字节纯ACK不算。坑3以为“四次挥手必须四次”。后来才搞明白如果双方同时说拜拜可以合并成三次。十一、下步目标三次握手、四次挥手搞清楚了。下一次靖哥哥说想试试飞鸽传书下期预告UDP - 相思传的快飞鸽传书在十二、写在最后这一次郭靖最大的收获SYN、ACK、FIN——三步确认四步道别。言而有信江湖有情。慢即是快快即是慢。打完收工886。

相关文章:

第十八篇技术笔记:三次握手、四次挥手——郭靖与蓉儿的“信令之约”

写在开篇:话说襄阳城头,雪还没化完。郭靖站在城墙上,望着南方,心里惦念着桃花岛上的黄蓉。蒙古大军压境,他已经三个月没收到黄蓉的消息了。他想写封信给蓉儿表达思念之情。用的是镖局押镖(TCP)—…...

别再按着按钮上电了!HC-05蓝牙模块AT指令模式一键进入的两种实用方法(附串口助手配置)

HC-05蓝牙模块AT指令模式一键进入的两种实用方法 每次调试HC-05蓝牙模块时,最让人头疼的就是进入AT指令模式的操作——按住按钮再上电。这个看似简单的动作在实际开发中却可能成为效率杀手。想象一下,当你需要反复修改参数时,每次都要小心翼翼…...

告别二维红海:空间计算(Spatial Computing)元年与前端工程师的升维破局

在当前全球计算机科学(CS)与软件工程的求职生态中,传统的前端开发(Front-end Development)正面临着前所未有的竞争压力。无数留学生熟练掌握了 React、Vue、TypeScript 以及各类主流打包工具,却在投递跨国科…...

终极开源学术字体解决方案:EB Garamond 12完整指南

终极开源学术字体解决方案:EB Garamond 12完整指南 【免费下载链接】EBGaramond12 项目地址: https://gitcode.com/gh_mirrors/eb/EBGaramond12 在学术写作和出版领域,选择一款既专业又优雅的字体往往成为困扰研究者的难题。EB Garamond 12作为一…...

怎样用Pomotroid番茄工作法计时器实现专注力翻倍:免费开源工具的完整指南

怎样用Pomotroid番茄工作法计时器实现专注力翻倍:免费开源工具的完整指南 【免费下载链接】pomotroid :tomato: Simple and visually-pleasing Pomodoro timer 项目地址: https://gitcode.com/gh_mirrors/po/pomotroid 你是否经常发现自己工作时分心&#xf…...

3个关键步骤:OpenCore Legacy Patcher让老Mac重获新生

3个关键步骤:OpenCore Legacy Patcher让老Mac重获新生 【免费下载链接】OpenCore-Legacy-Patcher Experience macOS just like before 项目地址: https://gitcode.com/GitHub_Trending/op/OpenCore-Legacy-Patcher 当你的MacBook Pro 2015在App Store中看到&…...

如何快速上手 Siesta:5 分钟构建你的第一个 REST 客户端

如何快速上手 Siesta:5 分钟构建你的第一个 REST 客户端 【免费下载链接】siesta The civilized way to write REST API clients for iOS / macOS 项目地址: https://gitcode.com/gh_mirrors/si/siesta Siesta 是一个为 iOS 和 macOS 设计的优雅 REST API 客…...

终极iOS自定义指南:无需越狱的Misaka完整教程

终极iOS自定义指南:无需越狱的Misaka完整教程 【免费下载链接】misaka iOS & tvOS customisation tool for KFD & MDC 项目地址: https://gitcode.com/gh_mirrors/mis/misaka Misaka是一款革命性的iOS和tvOS自定义工具,让你无需越狱即可…...

grpc-swift社区贡献指南:如何参与开源项目开发与维护

grpc-swift社区贡献指南:如何参与开源项目开发与维护 【免费下载链接】grpc-swift The Swift language implementation of gRPC. 项目地址: https://gitcode.com/gh_mirrors/grp/grpc-swift grp/grpc-swift是Swift语言实现的gRPC框架,为开发者提供…...

Vue-Netease-Music核心技术解析:Vue2+ElementUI实现专业级音乐播放器

Vue-Netease-Music核心技术解析:Vue2ElementUI实现专业级音乐播放器 【免费下载链接】vue-netease-music 🎵 基于 Vue2、Vue-CLI3 的高仿网易云 mac 客户端播放器(PC) Online Music Player 项目地址: https://gitcode.com/gh_mi…...

ml-internAPI设计最佳实践:构建易用的AI接口

ml-internAPI设计最佳实践:构建易用的AI接口 【免费下载链接】ml-intern 🤗 ml-intern: an open-source ML engineer that reads papers, trains models, and ships ML models 项目地址: https://gitcode.com/GitHub_Trending/ml/ml-intern ml-in…...

终极性能优化指南:BAM和CBAM注意力模块的部署与加速技巧

终极性能优化指南:BAM和CBAM注意力模块的部署与加速技巧 【免费下载链接】attention-module Official PyTorch code for "BAM: Bottleneck Attention Module (BMVC2018)" and "CBAM: Convolutional Block Attention Module (ECCV2018)" 项目地…...

Chess Alpha Zero 终极指南:从零开始构建国际象棋AI的完整教程

Chess Alpha Zero 终极指南:从零开始构建国际象棋AI的完整教程 【免费下载链接】chess-alpha-zero Chess reinforcement learning by AlphaGo Zero methods. 项目地址: https://gitcode.com/gh_mirrors/ch/chess-alpha-zero Chess Alpha Zero是一个基于Alpha…...

WSL基础命令终极教程:从零开始掌握Linux命令行

WSL基础命令终极教程:从零开始掌握Linux命令行 【免费下载链接】WSL Source code behind the Windows Subsystem for Linux documentation. 项目地址: https://gitcode.com/gh_mirrors/wsl3/WSL Windows Subsystem for Linux(WSL)是微…...

为什么选择gtk4-rs:Rust GUI开发的5大优势解析

为什么选择gtk4-rs:Rust GUI开发的5大优势解析 【免费下载链接】gtk4-rs Rust bindings of GTK 4 项目地址: https://gitcode.com/gh_mirrors/gt/gtk4-rs gtk4-rs是GTK 4的Rust绑定库,为开发者提供了使用Rust语言构建跨平台图形用户界面的强大工具…...

如何快速恢复Windows 11任务栏拖放功能:完整使用指南

如何快速恢复Windows 11任务栏拖放功能:完整使用指南 【免费下载链接】Windows11DragAndDropToTaskbarFix "Windows 11 Drag & Drop to the Taskbar (Fix)" fixes the missing "Drag & Drop to the Taskbar" support in Windows 11. It…...

ARM Cortex-A7 MPCore处理器勘误分析与解决方案

1. ARM Cortex-A7 MPCore处理器勘误概述在嵌入式系统开发领域,处理器勘误(Errata)是每个工程师都必须面对的现实问题。作为ARMv7-A架构中的经典低功耗多核处理器,Cortex-A7 MPCore广泛应用于各种嵌入式设备和物联网终端。我在实际项目中使用这款处理器时…...

Furion高级特性详解:AOP、动态代理与反射机制

Furion高级特性详解:AOP、动态代理与反射机制 【免费下载链接】Furion 让 .NET 开发更简单,更通用,更流行。 项目地址: https://gitcode.com/gh_mirrors/furi/Furion Furion是一个让.NET开发更简单、更通用、更流行的开源框架。本文将…...

NCM文件解密终极指南:ncmdump工具快速实现网易云音乐格式转换

NCM文件解密终极指南:ncmdump工具快速实现网易云音乐格式转换 【免费下载链接】ncmdump 项目地址: https://gitcode.com/gh_mirrors/ncmd/ncmdump 你是否曾经从网易云音乐下载了喜欢的歌曲,却发现在其他播放器上无法播放?这就是NCM格…...

OpenCV HOG特征与SVM实现目标检测全流程指南

1. 项目概述:基于HOG特征的目标检测训练指南在计算机视觉领域,目标检测一直是核心挑战之一。不同于简单的图像分类,检测任务需要同时完成目标定位和识别两项工作。传统方法中,方向梯度直方图(HISTOGRAM OF ORIENTED GR…...

腾讯青云计划到底适合谁,不是所有人都该冲

适合人群:对腾讯青云计划感兴趣,但不确定自己是否适合的技术类学生 腾讯青云计划最容易让人误会的地方,就是名字太像“所有技术生都该试一下”的机会。 其实它更像一把筛子,而且筛得很细。 如果你没先把这个定位看清&#xff0c…...

崩坏星穹铁道三月七小助手:智能游戏伴侣的革命性体验

崩坏星穹铁道三月七小助手:智能游戏伴侣的革命性体验 【免费下载链接】March7thAssistant 崩坏:星穹铁道全自动 三月七小助手 项目地址: https://gitcode.com/gh_mirrors/ma/March7thAssistant 深夜11点,疲惫的李明终于结束了加班&…...

Maid项目未来展望:移动AI应用的路线图与发展趋势

Maid项目未来展望:移动AI应用的路线图与发展趋势 【免费下载链接】maid Maid is a free and open source application for interfacing with llama.cpp models locally, and with Anthropic, DeepSeek, Ollama, Mistral and OpenAI models remotely. 项目地址: ht…...

Prophet时间序列预测:原理、实践与调优指南

1. 时间序列预测与Prophet库概述时间序列预测是数据分析领域中最具挑战性的任务之一。无论是零售业的销售预测、金融市场的趋势分析,还是工业设备的维护预警,准确预测未来值都能带来显著的商业价值。传统的时间序列分析方法如ARIMA虽然强大,但…...

Pusher-js 最佳实践总结:避免常见陷阱的20个经验分享

Pusher-js 最佳实践总结:避免常见陷阱的20个经验分享 【免费下载链接】pusher-js Pusher Javascript library 项目地址: https://gitcode.com/gh_mirrors/pu/pusher-js Pusher-js 是一款强大的实时通信 JavaScript 库,广泛应用于构建实时聊天、实…...

Transloco 迁移指南:从 Angular i18n 或 ngx-translate 无缝迁移

Transloco 迁移指南:从 Angular i18n 或 ngx-translate 无缝迁移 【免费下载链接】transloco 🚀 😍 The internationalization (i18n) library for Angular 项目地址: https://gitcode.com/gh_mirrors/tr/transloco Transloco 是 Angu…...

抖音视频下载工具终极指南:如何一键批量下载无水印视频

抖音视频下载工具终极指南:如何一键批量下载无水印视频 【免费下载链接】douyin-downloader A practical Douyin downloader for both single-item and profile batch downloads, with progress display, retries, SQLite deduplication, and browser fallback supp…...

OpenCore Legacy Patcher深度解析:如何让老款Mac突破系统限制

OpenCore Legacy Patcher深度解析:如何让老款Mac突破系统限制 【免费下载链接】OpenCore-Legacy-Patcher Experience macOS just like before 项目地址: https://gitcode.com/GitHub_Trending/op/OpenCore-Legacy-Patcher OpenCore Legacy Patcher是一个开源…...

如何5步完成微信聊天记录完整备份:终极数据安全解决方案

如何5步完成微信聊天记录完整备份:终极数据安全解决方案 【免费下载链接】WeChatExporter 一个可以快速导出、查看你的微信聊天记录的工具 项目地址: https://gitcode.com/gh_mirrors/wec/WeChatExporter 你是否曾担心手机里的珍贵对话会因设备故障而永久丢失…...

LLM在Verilog代码生成中的技术演进与实践

1. LLM在Verilog代码生成中的技术演进作为一名在数字电路设计领域工作多年的工程师,我见证了硬件描述语言(Verilog)设计方式的革命性变化。传统的手动编写RTL代码方式正逐渐被基于大型语言模型(LLM)的自动化方法所补充甚至替代。Verilog代码生成不同于普通编程语言&…...