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

TCP 是用来解决什么问题:从 IP 的不可靠到可靠的端到端通信

TCP 是用来解决什么问题从 IP 的不可靠到可靠的端到端通信01. 前言为什么有了 IP 还不够02. IP 协议的四大先天缺陷03. TCP 要解决的六大核心问题04. 问题一丢包 → 确认 超时重传4.1 问题描述4.2 TCP 的解决方案05. 问题二乱序 → 序列号 排序5.1 问题描述5.2 TCP 的解决方案06. 问题三重复 → 序列号去重6.1 问题描述6.2 TCP 的解决方案07. 问题四无连接 → 三次握手建立连接7.1 问题描述7.2 TCP 的解决方案三次握手08. 问题五收发速度不匹配 → 流量控制8.1 问题描述8.2 TCP 的解决方案滑动窗口09. 问题六网络拥堵 → 拥塞控制9.1 问题描述9.2 TCP 的解决方案拥塞控制算法10. 汇总TCP 解决的 6 个问题及对应机制11. 完整流程图从发送到接收TCP 解决了什么12. 哪些场景不需要 TCP为什么13. 总结The Begin点点关注收藏不迷路01. 前言为什么有了 IP 还不够互联网的底层是IP 协议Internet Protocol它负责将数据包从源主机发送到目标主机。但 IP 协议只提供“尽力而为”的服务——不保证数据包能到达、不保证顺序、不保证不重复。如果 IP 已经能把数据送到对方电脑为什么还需要 TCP因为现实网络中存在丢包、乱序、重复、拥塞、流量不匹配等问题。TCP 就是在 IP 的“不可靠”之上构建一个“可靠”的传输层协议。本文从 IP 的先天缺陷出发逐一分析 TCP 要解决的 6 大核心问题以及它如何解决。02. IP 协议的四大先天缺陷IP 层提供的是无连接、不可靠的数据报服务发送端 IP 层 网络 接收端 IP 层 │ │ │ │──── 包1 ────────│─────────────────→│ ✅ 可能到达 │──── 包2 ────────│───── ✗ 丢包 ─────│ ❌ 可能丢失 │──── 包3 ────────│─────────────────→│ ✅ 可能到达 │──── 包4 ────────│─────────→ 包4 │ ❌ 可能乱序包4比包3先到 │──── 包5 ────────│─────────────────→│ ❌ 可能重复网络重传导致IP 的问题具体表现丢包路由器拥塞、线路故障数据包被丢弃乱序不同路由路径导致后发的包先到达重复超时重传导致接收方收到同一数据包的多个副本无流量控制发送方太快会淹没接收方导致丢包无拥塞控制发送方太快会堵塞网络加剧丢包无连接概念每个包独立路由没有“会话”状态TCP 的目标在 IP 的这个“烂摊子”上为用户提供一个可靠的、有序的、不重复的、带流量控制和拥塞控制的字节流连接。03. TCP 要解决的六大核心问题┌─────────────────────────────────────────────────────────────────┐ │ TCP 要解决的问题 │ ├─────────────────────────────────────────────────────────────────┤ │ 1. 丢包问题 → 如何发现丢了丢了怎么办 │ │ 2. 乱序问题 → 如何把乱序的包排好队 │ │ 3. 重复问题 → 如何识别并丢弃重复包 │ │ 4. 连接性问题 → 如何让双方知道“我们在通信” │ │ 5. 流量控制问题 → 发送太快接收方处理不过来怎么办 │ │ 6. 拥塞控制问题 → 发送太快网络本身撑不住了怎么办 │ └─────────────────────────────────────────────────────────────────┘下面逐一分析每个问题的解决方案。04. 问题一丢包 → 确认 超时重传4.1 问题描述IP 网络不保证数据包一定能到达。路由器丢包、WiFi 干扰、线路故障随时可能丢包。4.2 TCP 的解决方案发送端 接收端 │ │ │──── 发送 数据包(seq100) ─────────────→│ │ │ │ 包丢失了 │ │ │ │ [超时定时器到期没收到 ACK] │ │ │ │──── 重传 数据包(seq100) ─────────────→│ │ │ │←────────────────────────── ACK(101) ───│核心机制确认应答ACK接收方收到数据后回复 ACK确认号 下一个期望的字节序号超时重传RTO发送方启动定时器超时未收到 ACK 则重传快速重传收到 3 个重复 ACK 时立即重传不等超时05. 问题二乱序 → 序列号 排序5.1 问题描述IP 路由是动态的包1 走拥堵路径晚到包2 走快速路径早到导致接收方先看到包2。发送顺序 包1(seq100) → 包2(seq200) → 包3(seq300) │ │ │ ▼ ▼ ▼ [慢路径] [快路径] [快路径] │ │ │ └──────┬───────┴───────┬──────┘ ▼ ▼ 接收顺序 包2(seq200) → 包3(seq300) → 包1(seq100)乱序5.2 TCP 的解决方案每个字节都有唯一的序列号Sequence Number。接收方维护一个重排序缓冲区接收方收到的包乱序 收到包2 (seq200, 100字节) → 存入缓冲区等待前面的数据 收到包3 (seq300, 100字节) → 存入缓冲区继续等待 收到包1 (seq100, 100字节) → 缺失的补齐了按顺序提交给应用 重排序后提交给应用 字节 100-199 → 字节 200-299 → 字节 300-399核心接收方只提交连续的、有序的数据给应用层乱序的数据暂存。06. 问题三重复 → 序列号去重6.1 问题描述发送方因超时重传了一个包但实际上原包并没有丢只是延迟到达导致接收方收到两个相同的包。发送端 接收端 │ │ │──── 发送 包(seq100) ─────────────────→│ ✅ 收到 │ ACK 在路上延迟了 │ │ │ │ [超时没收到 ACK] │ │ │ │──── 重传 同一个包(seq100) ───────────→│ ✅ 又收到一次 │ │ │←────────────────────────── ACK(200) ───│6.2 TCP 的解决方案接收方根据序列号识别重复包接收方逻辑 第一次收到 seq100100字节 存入缓冲区标记 100-199 已接收 第二次收到 seq100 检查序列号范围发现已经收过了 → 丢弃重复包 但还是要回复 ACK告诉发送方已收到避免继续重传07. 问题四无连接 → 三次握手建立连接7.1 问题描述IP 是无连接的每个数据包独立路由。但应用层需要一个“会话”概念——双方需要知道“我们正在通信”并初始化状态序列号、窗口等。7.2 TCP 的解决方案三次握手客户端 服务器 │ │ │────── 1. SYN (seqx) ─────────────────→│ 客户端我想建立连接我的初始序号是x │ │ │←──── 2. SYNACK (seqy, ackx1) ──────│ 服务器好的我的初始序号是y确认收到x │ │ │────── 3. ACK (acky1) ───────────────→│ 客户端确认收到你的序号y │ │ ▼ ▼ ESTABLISHED ESTABLISHED解决的问题双方确认对方存活且愿意通信同步初始序列号防止旧连接的历史包干扰新连接协商窗口大小等参数08. 问题五收发速度不匹配 → 流量控制8.1 问题描述发送方以 100MB/s 的速度发送接收方只能以 10MB/s 的速度处理。没有控制的话接收方缓冲区会溢出数据被丢弃。8.2 TCP 的解决方案滑动窗口接收方在 ACK 包中携带窗口Window字段告诉发送方“我的缓冲区还能接收 N 字节”。发送端 接收端 │ │ │←────────────────── ACK(1001, win1024)─│ 接收方我能再收1024字节 │ │ │──── 发送最多 1024 字节 ───────────────→│ 发送方好我只发你允许的量 │ │ │←────────────────── ACK(2049, win512)──│ 接收方处理了一些窗口变小了 │ │ │──── 发送最多 512 字节 ─────────────────→│ 发送方跟着降速效果发送速度自动匹配接收方的处理能力防止接收方被淹没。09. 问题六网络拥堵 → 拥塞控制9.1 问题描述即使接收方处理能力很强如果网络本身拥堵路由器队列满了发送太快会导致路由器丢包。9.2 TCP 的解决方案拥塞控制算法拥塞控制的核心维护一个 拥塞窗口cwnd实际发送量 min(接收窗口, 拥塞窗口) ▲ │ 拥塞窗口 │ /──────── 大小 │ / │ / │ / 拥塞避免阶段线性增长 │ / │ / 慢启动阶段指数增长 │/ └──────────────────────► 时间 丢包发生时窗口减半拥塞发生四大组件机制作用慢启动连接建立后从一个小窗口开始指数增长直到达到阈值拥塞避免达到阈值后线性增长每个 RTT 增加 1 个 MSS快速重传收到 3 个重复 ACK立即重传丢包不等超时快速恢复快速重传后窗口减半而不是回到 1避免过度降速10. 汇总TCP 解决的 6 个问题及对应机制问题IP 的行为TCP 的解决方案丢包不保证送达确认应答ACK 超时重传 快速重传乱序可能乱序到达序列号 重排序缓冲区重复可能重复到达序列号去重无连接每个包独立三次握手建立状态机 四元组标识连接速度不匹配无控制流量控制滑动窗口网络拥堵无控制拥塞控制慢启动 拥塞避免 快重传11. 完整流程图从发送到接收TCP 解决了什么应用层数据 │ ▼ ┌─────────────────────────────────────────────────────────────┐ │ TCP 发送方 │ ├─────────────────────────────────────────────────────────────┤ │ 1. 将数据切成 MSS 大小的段 │ │ 2. 给每个字节编号序列号 │ │ 3. 根据 拥塞窗口 接收窗口 决定发送多少 │ │ 4. 发送数据同时启动重传定时器 │ │ 5. 收到 ACK → 确认送达窗口滑动继续发送 │ │ 6. 超时未 ACK 或 3 个重复 ACK → 重传 │ └─────────────────────────────────────────────────────────────┘ │ ▼ ┌─────────────────────────────────────────────────────────────┐ │ IP 网络不可靠 │ ├─────────────────────────────────────────────────────────────┤ │ 可能丢包、乱序、重复、延迟 │ └─────────────────────────────────────────────────────────────┘ │ ▼ ┌─────────────────────────────────────────────────────────────┐ │ TCP 接收方 │ ├─────────────────────────────────────────────────────────────┤ │ 1. 收到数据包根据序列号判断 │ │ - 重复 → 丢弃 │ │ - 乱序 → 放入重排序缓冲区 │ │ - 正好是期望的序号 → 交给应用并尝试从缓冲区取出连续数据 │ │ 2. 发送 ACK确认号 下一个期望的字节序号 │ │ 3. 通告自己的接收窗口还能收多少 │ └─────────────────────────────────────────────────────────────┘ │ ▼ 应用层收到有序、可靠、不重复的数据12. 哪些场景不需要 TCP为什么TCP 解决了可靠性问题但代价是延迟增加、吞吐量波动、头部开销大。场景用什么协议为什么不用 TCP实时视频/语音UDP丢几个包没关系延迟更致命DNS 查询UDP一个包搞定不需要连接开销游戏FPS/竞速UDP宁可丢包也不等重传体验优先内部高速传输RDMAInfiniBandTCP 内核开销太大HTTP/3QUICUDPQUIC解决 TCP 队头阻塞但又想有可靠性一句话需要可靠传输用 TCP需要低延迟、可容忍丢包用 UDP。13. 总结┌─────────────────────────────────────────────────────────────────┐ │ TCP 到底解决了什么问题一句话总结 │ ├─────────────────────────────────────────────────────────────────┤ │ TCP 在不可靠的 IP 网络上通过 │ │ 序列号 确认 重传 排序 去重 窗口 拥塞控制 │ │ 为用户提供了一个 │ │ 可靠的、有序的、不重复的、带流量控制和拥塞控制的 │ │ 双向字节流连接。 │ └─────────────────────────────────────────────────────────────────┘面试回答模板TCP 主要解决 IP 层的四大缺陷丢包、乱序、重复、无连接。通过确认重传解决丢包通过序列号解决乱序和重复通过三次握手建立连接。此外还通过滑动窗口解决流量控制问题通过拥塞控制解决网络拥堵问题。The End点点关注收藏不迷路

相关文章:

TCP 是用来解决什么问题:从 IP 的不可靠到可靠的端到端通信

TCP 是用来解决什么问题:从 IP 的不可靠到可靠的端到端通信01. 前言:为什么有了 IP 还不够?02. IP 协议的四大先天缺陷03. TCP 要解决的六大核心问题04. 问题一:丢包 → 确认 超时重传4.1 问题描述4.2 TCP 的解决方案05. 问题二&…...

到底什么是 TCP 连接:从三次握手到四次挥手,从数据结构到状态机

到底什么是 TCP 连接:从三次握手到四次挥手,从数据结构到状态机01. 前言:每天都在用,却说不清它是什么02. 一句话定义03. TCP 连接不是物理的,而是逻辑的04. TCP 连接的核心标识:四元组05. TCP 连接在内核中…...

Python @contextmanager 装饰器完全指南

在Python编程实践中,资源管理是一个永恒的话题。无论是文件句柄、数据库连接还是临时状态变更,我们都需要确保资源被正确分配并在使用后得到妥善清理。虽然传统的try...finally语句可以解决这个问题,但Python提供了更加优雅的解决方案——上下…...

EC数据下载和可视化产品python实现

欧洲中期天气预报中心(ECMWF,European Centre for Medium-Range Weather Forecasts)是全球顶尖的气象研究和业务预报中心之一。其发布的数据,常被业内简称为“EC数据”,因高精度与高稳定性,是全球气象预报、…...

数据集成与 ETL 实践:从设计到优化

数据集成与 ETL 实践:从设计到优化 前言 作为一个在数据深渊里捞了十几年 Bug 的女码农,我深知数据集成和 ETL(Extract, Transform, Load)在企业数据管理中的重要性。随着数据量的爆炸式增长和数据来源的多样化,数据集…...

数据治理与数据质量:从策略到实践

数据治理与数据质量:从策略到实践 前言 作为一个在数据深渊里捞了十几年 Bug 的女码农,我深知数据治理和数据质量在企业数据管理中的重要性。随着数据量的爆炸式增长和数据类型的多样化,数据治理和数据质量已经成为企业数据管理的核心挑战。今…...

云原生数据库的设计与实践:从架构到部署

云原生数据库的设计与实践:从架构到部署 前言 作为一个在数据深渊里捞了十几年 Bug 的女码农,我深知云原生技术对数据库的影响。随着云计算的快速发展,云原生数据库已经成为数据库技术的重要发展方向。今天,我就来聊聊云原生数据库…...

网络协议封神考点:TCP协议是如何保证可靠传输的?原理+流程图+硬核详解

网络协议封神考点:TCP协议是如何保证可靠传输的?原理流程图硬核详解一、前言二、基础定义:什么是TCP可靠传输?三、TCP保证可靠传输的6大核心机制(必考)3.1 机制1:面向连接(三次握手 …...

Spring-AI 第 13 章 - 多模态消息处理详解

📚 理论基础 什么是多模态 AI? 多模态 AI(Multimodal AI) 是能够同时处理和生成多种类型数据(文本、图像、音频等)的人工智能系统。 多模态模型架构 ┌──────────────┐ ┌──────────────┐ │ 图像输入 │ │ 文本输入 …...

**发散创新:基于Go语言实现的Raft共识算法实战解析**在分布式系统中,**一

发散创新:基于Go语言实现的Raft共识算法实战解析 在分布式系统中,一致性是核心挑战之一。而Raft共识算法因其简洁性和可理解性,已成为当前主流的分布式一致性协议(如etcd、Consul均采用Raft)。本文将带你深入用Go语言从…...

# 发散创新:基于Python与Stable Diffusion的AI绘画自动化流程设计与实践

发散创新:基于Python与Stable Diffusion的AI绘画自动化流程设计与实践 在人工智能技术飞速发展的今天,AI绘画已从实验室走向大众创作场景。如何将这一前沿能力融入开发者工作流?本文以 Python Stable Diffusion API(如InvokeAI或…...

**发散创新:基于 Rust的微服务生态构建与性能优化实战**在现代云原生架构中,**Rust语言正迅速成为构建高并发、低延迟微服

发散创新:基于 Rust 的微服务生态构建与性能优化实战 在现代云原生架构中,Rust 语言正迅速成为构建高并发、低延迟微服务的首选工具之一。它不仅提供了媲美 C/C 的性能,还通过所有权机制彻底避免了内存安全问题。本文将围绕 Rust 在微服务生态…...

2026届最火的六大降重复率神器实际效果

Ai论文网站排名(开题报告、文献综述、降aigc率、降重综合对比) TOP1. 千笔AI TOP2. aipasspaper TOP3. 清北论文 TOP4. 豆包 TOP5. kimi TOP6. deepseek 目前人工智能生成内容大范围运用的情形下,致使 AIGC 检测识别率降低的工具适时出…...

场效应管MOS

场效应管 场效应管又称场效应晶体管(Field Effect Transistor,缩写为FET),它与三极管一样,具有放大能力。场效应管有漏极(D极)、栅极(G极)和源极(S极&#xf…...

5个突破边界技巧:OpenSpeedy游戏变速工具深度优化指南

5个突破边界技巧:OpenSpeedy游戏变速工具深度优化指南 【免费下载链接】OpenSpeedy 🎮 An open-source game speed modifier. 项目地址: https://gitcode.com/gh_mirrors/op/OpenSpeedy 副标题:如何通过用户态Hook技术实现游戏帧率自由…...

新手福音:在快马平台用AI生成openclaw命令实操案例,轻松入门运维自动化

作为一个刚接触运维的新手,第一次看到openclaw这个命令时确实有点懵。不过最近在InsCode(快马)平台上发现了一个超实用的功能,可以通过AI直接生成可运行的openclaw示例代码,还能实时测试效果,简直是新手福利!下面我就用…...

保姆级教程:在Quartus Prime 18.0中手把手配置NCO IP核并完成Modelsim仿真

保姆级教程:在Quartus Prime 18.0中手把手配置NCO IP核并完成Modelsim仿真 数字信号处理是FPGA开发中的核心技能之一,而数控振荡器(NCO)作为生成精确频率信号的关键IP核,在通信系统、雷达信号处理等领域有着广泛应用。…...

C语言三大控制结构:零基础学循环与选择

C语言编程里,控制结构用以构架程序逻辑,是新手入门的关键要点,掌握顺序、选择、循环这三大基本控制结构,可使你脱离单纯顺序代码编写,达成更复杂、更灵活的程序逻辑,本文会将C语言控制结构的核心知识点讲解…...

【深度解析】Hermes Agent:具备学习循环的开源 AI 代理如何落地到你的开发工作流?

摘要 Hermes Agent 是 News Research 推出的开源 AI Agent 系统,不只是“聊天包装器”,而是带有持久化记忆、自我技能学习与多通道接入的完整代理运行环境。本文从架构原理到落地实践,系统解析 Hermes 的学习循环、模型接入方式(云…...

CEEMDAN-VMD-Transformer-GRU二次分解+编码器+门控循环单元多元时间序列预测

一、研究背景 实际工程与科学数据(如振动信号、电力负荷、金融时序)常呈现非线性、非平稳特征,单一预测模型难以充分提取多尺度信息。为此,结合自适应信号分解(CEEMDAN、VMD)与深度学习(Transfo…...

针对波动计算复杂性的吸收边界条件(PML 用于一般波动方程)附Matlab代码

✅作者简介:热爱科研的Matlab仿真开发者,擅长数据处理、建模仿真、程序设计、完整代码获取、论文复现及科研仿真。🍎 往期回顾关注个人主页:Matlab科研工作室🍊个人信条:格物致知,完整Matlab代码及仿真咨询…...

【LeetCode 刷题日】19.删除链表的倒数第n个节点

🔥个人主页:北极的代码(欢迎来访) 🎬作者简介:java后端学习者评论和 ❄️个人专栏:苍穹外卖日记,SSM框架深入,JavaWeb ✨命运的结局尽可永在,不屈的挑战却不可…...

【AI实战项目】项目六:知识图谱构建与应用实战

分享一个大牛的人工智能教程。零基础!通俗易懂!风趣幽默!希望你也加入到人工智能的队伍中来!请轻击人工智能教程https://www.captainai.net/troubleshooter 项目背景: 在当今信息爆炸的时代,精准理解和应…...

人流后多久干净才算正常?行业洞察与科学修护指南

人工流产后,出血排净时间是判断身体恢复状态的核心指标,也是女性关注的首要问题。结合行业研究与临床实践,本文将深入解析人流后出血的正常范围、异常信号,同时结合行业修护标准,为女性提供科学、实用的恢复指引&#…...

宫外孕打掉需要住院吗?术后修护核心指南

宫外孕作为妇科高发急腹症,不少女性存在认知误区,疑惑“宫外孕打掉是否需要住院”。事实上,宫外孕绝非普通流产,其处理必须住院,且术后修护直接影响女性后续生殖健康。本文结合行业洞察,围绕宫外孕住院必要…...

告别繁琐手工操作:工资条生成器使用指南

对于许多财务人员来说,每月制作工资条都是一项让人头疼的工作。 手工制作不仅要花费大量时间,还容易出现各种错误,影响工作效率和准确性。 今天,我们就来详细介绍一款能够彻底改变这种状况的工具——工资条生成器。 工资条生成…...

工资条生成器:财务人员的高效办公利器

在企业财务管理工作中,工资条的制作与发放是一项既繁琐又重要的任务。 传统的手工制作方式不仅耗时耗力,还容易出现数据错误和格式不统一的问题。 工资条生成器的出现,为财务人员带来了全新的解决方案。 这款软件专门针对财务工作场景设计…...

龙迅LT9211D芯片解析:如何实现MIPI与双端口LVDS的高效转换

1. 龙迅LT9211D芯片的核心价值 第一次接触龙迅LT9211D芯片是在一个车载显示项目上,当时客户要求实现4K视频从主控芯片到双屏显示的无损传输。这个看似简单的需求背后,其实隐藏着MIPI和LVDS两种信号标准的转换难题。LT9211D的出现完美解决了这个问题&…...

Ubuntu 22.04下Milvus集群部署实战:从Docker提取二进制文件的完整指南

Ubuntu 22.04下Milvus集群部署实战:从Docker提取二进制文件的完整指南 在向量数据库领域,Milvus凭借其出色的性能和可扩展性已成为众多AI应用的首选存储引擎。虽然官方推荐使用Docker或Kubernetes进行部署,但在某些生产环境中,直接…...

W5500 TCP客户端实战 | 02 - 从寄存器配置到数据收发的完整流程解析

1. W5500网络寄存器配置详解 第一次接触W5500芯片时,我被它密密麻麻的寄存器地址搞得头晕眼花。后来发现只要抓住几个核心寄存器,配置起来就像填快递单一样简单。先说说最关键的四个本地网络寄存器,它们相当于设备的"身份证"&#…...