【网络】TCP常考知识点详解

TCP报文结构

   

TCP报文由**首部(Header)数据(Data)**两部分组成。首部包括固定部分(20字节)和可选选项(最多40字节),总长度最大为60字节。

1. 首部固定部分
  1. 源端口(16位)目的端口(16位)

    • 标识发送和接收的应用程序(如HTTP默认端口80)。

  2. 序列号(32位)

    • 表示当前报文段数据部分的第一个字节的序号,确保数据按序传输。

  3. 确认号(32位)

    • 期望收到的下一个字节的序号,表示接收方已正确接收之前的所有数据。

  4. 数据偏移(4位)

    • 指示首部长度(以4字节为单位)。例如,值为5表示首部长度20字节。

  5. 保留字段(6位)

    • 未使用,必须置0。

  6. 控制位(6位)

    • URG:紧急指针有效,优先处理紧急数据。

    • ACK:确认号有效(连接建立后通常为1)。

    • PSH:接收方应立即将数据推送给应用层。

    • RST:强制重置异常连接。

    • SYN:建立连接时同步序列号。

    • FIN:正常关闭连接。

  7. 窗口大小(16位)

    • 接收方的可用缓冲区大小,用于流量控制(滑动窗口机制)。

  8. 校验和(16位)

    • 计算包括伪首部(源/目的IP、协议类型、TCP长度)、TCP首部和数据,确保数据完整性。

  9. 紧急指针(16位)

    • 当URG=1时有效,指向紧急数据的结束位置。

2. 选项部分(可变长度,最多40字节)
  • MSS(最大报文段长度):在三次握手时协商,避免IP分片。

  • 窗口扩大因子:扩展窗口大小(原16位窗口最大为65535)。

  • 时间戳:计算往返时间(RTT)和防止序列号回绕(PAWS机制)。

  • SACK(选择性确认):允许接收方报告非连续接收的数据块,提升重传效率。

3. 填充字段
  • 确保首部长度是4字节的倍数。

4. 数据部分
  • 上层协议(如HTTP、FTP)传递的数据,长度由MSS和窗口大小共同决定。

TCP的特点

  1. 面向连接:TCP发送数据前需要通过三次握手建立全双工通信,结束数据发送后通过四次挥手关闭连接
  2. 可靠性:TCP通过确认和重传、快速重传、拥塞控制、流量控制、有序性、超时重传等机制确保数据可靠传输
    1. 确认和重传:接收方收到数据后会发送确认ACK给发送方,若发送方经过超时时间未收到ACK,则会重传
    2. 流量控制:接收方会通过滑动窗口(循环数组,用三个指针给他分区)的机制告诉发送方可接收数据的大小,避免发送方发送大量数据拥塞在接收方的缓冲区
    3. 拥塞控制:发送方根据网络的拥塞情况动态调整发送速率,避免造成网络拥塞
    4. 有序性:接收方根据TCP头部的序列号重新对数据进行排序
  3. 头部开销大:TCP报文头部(源/目的端口+**序列号/确认号**+首部长度+**标志位(SYN/ACK/FIN/RST)**+**窗口大小(RWND)**+校验和),增加传输开销
    • 源/目的端口 标识了应用进程;序列号和确认号可以进行确认和重传,同时保证数据有序;
    • 标志位(指示TCP会话期间的特定状态):**SYN-同步,ACK-确认数据包接收,FIN-结束**,RST-重置TCP连接,URG-紧急数据,PSH-立即推送数据,
  4. 全双工通信:TCP协议允许通信双方同时进行数据的发送和接收

TCP超时重传

  • RTT(Round-Trip Time)往返时延:数据包在网络中的往返时延(网络波动造成RTT**动态变化**)
  •  RTO(Retransmission Timeout)超时重传时间:RTO应略大于RTT。太大会降低网络的传输效率;小于RTT则会造成不必要的超时重传,增大网络负荷
  • 发送方在RTO内未收到ACK,说明网络严重拥塞,发送方重置CWND(拥塞窗口)进行**慢启动**,逐步增加发送量,降低网络过载风险
  • 拥塞窗口CWND :发送方维护的变量,初始值默认为1 MSS(1460 Byte)
  • 慢启动阈值_ssthresh:窗口增长模式的切换点;初始值较高(如接收方通告窗口大小)发生拥塞时动态调整
  • 慢启动算法流程
    1. 初始化阶段:TCP连接建立后/超时重传后,set CWND= 1 MSS,ssthresh初始为较大值
    2. 指数增长阶段:每收到一个和ack,cwnd增加1MSS(每个RTT内,CWND翻倍):
      1. 假设RTT固定100ms,初始CWND= 1 MSS
      2. 第0ms,发送一个报文 cwnd =1
      3. 第100ms:收到ack,cwnd=2(第100-200ms 发送2个报文)
      4. 第200ms:收到2个ack,每个ack触发cwnd+1, cwnd=4(第200-300ms 发送四个报文)
      5. 第300ms:收到4个ack,cwnd=8;
    3. 切换至**拥塞避免**:<u>*cwnd >= ssthresh*</u> 时,结束慢启动进入**线性增长**的拥塞避免阶段(每RTT,CWND增长1 MSS)
    4. 拥塞处理**:
      1. 超时丢包:严重拥塞,重置ssthresh=MAX(CWND/2,2 MSS),CWND = 1 MSS,重新***慢启动***
      2. 快速重传/恢复:(重复ACK触发)调整ssthresh= CWND/2 ,CWND=ssthresh+3(3个重复的ACK),直接进入***拥塞避免***

TCP快速重传

        发送方连续收到**三个重复ACK**(RFC经验)时,说明网络单包丢失,发送方CWND减半,进行快速重传

TCP拥塞控制与流量控制

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/diannao/73072.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

算法1-6 一元三次方程求解

题目描述 有形如&#xff1a;ax3bx2cxd0 这样的一个一元三次方程。给出该方程中各项的系数&#xff08;a,b,c,d 均为实数&#xff09;&#xff0c;并约定该方程存在三个不同实根&#xff08;根的范围在 −100 至 100 之间&#xff09;&#xff0c;且根与根之差的绝对值 ≥1。要…

05.基于 TCP 的远程计算器:从协议设计到高并发实现

&#x1f4d6; 目录 &#x1f4cc; 前言&#x1f50d; 需求分析 &#x1f914; 我们需要解决哪些问题&#xff1f; &#x1f3af; 方案设计 &#x1f4a1; 服务器架构 &#x1f680; 什么是协议&#xff1f;为什么要设计协议&#xff1f; &#x1f4cc; 结构化数据的传输问题 …

大数据面试之路 (一) 数据倾斜

记录大数据面试历程 数据倾斜 大数据岗位 &#xff0c;数据倾斜面试必问的一个问题。 一、数据倾斜的表现与原因 表现 某个或某几个Task执行时间过长&#xff0c;其他Task快速完成。 Spark/MapReduce作业卡在某个阶段&#xff08;如reduce阶段&#xff09;&#xff0c;日志显…

仅仅使用pytorch来手撕transformer架构(3):编码器模块和编码器类的实现和向前传播

仅仅使用pytorch来手撕transformer架构(2)&#xff1a;编码器模块和编码器类的实现和向前传播 往期文章&#xff1a; 仅仅使用pytorch来手撕transformer架构(1)&#xff1a;位置编码的类的实现和向前传播 最适合小白入门的Transformer介绍 仅仅使用pytorch来手撕transformer…

《OpenCV》—— dlib(换脸操作)

文章目录 dlib换脸介绍仿射变换在 dlib 换脸中的应用 换脸操作 dlib换脸介绍 dlib 换脸是基于 dlib 库实现的一种人脸替换技术&#xff0c;以下是关于它的详细介绍&#xff1a; 原理 人脸检测&#xff1a;dlib 库中包含先进的人脸检测器&#xff0c;如基于 HOG&#xff08;方向…

机器学习中的梯度下降是什么意思?

梯度下降&#xff08;Gradient Descent&#xff09;是机器学习中一种常用的优化算法&#xff0c;用于最小化损失函数&#xff08;Loss Function&#xff09;。通过迭代调整模型参数&#xff0c;梯度下降帮助模型逐步逼近最优解&#xff0c;从而提升模型的性能。 1.核心思想 梯…

三、Docker 集群管理与应用

&#xff08;一&#xff09;项目案例 1、准备主机 &#xff08;1&#xff09;关闭防火墙&#xff0c;或者开放TCP端口2377&#xff08;用于集群管理通信&#xff09;、TCP/UPD端口7946&#xff08;用于节点之间的通信&#xff09;、UDP端口4789&#xff08;用于overlay网络流…

网络DNS怎么更改?

访问速度慢或某些网站无法打开?改变网络DNS设置可能会帮助解决这些问题。本文将详细介绍如何更改网络DNS&#xff0c;包括更改的原因、具体步骤。 一、为什么要更改DNS? 更改DNS的原因有很多&#xff0c;以下是一些主要的考虑因素&#xff1a;某些公共DNS服务器的响应速度比…

江科大51单片机笔记【12】DS18B20温度传感器(上)

写在前言 此为博主自学江科大51单片机&#xff08;B站&#xff09;的笔记&#xff0c;方便后续重温知识 在后面的章节中&#xff0c;为了防止篇幅过长和易于查找&#xff0c;我把一个小节分成两部分来发&#xff0c;上章节主要是关于本节课的硬件介绍、电路图、原理图等理论…

基于springboot+vue的佳途旅行分享预约平台

一、系统架构 前端&#xff1a;vue2 | element-ui | html 后端&#xff1a;springboot | mybatis-plus 环境&#xff1a;jdk1.8 | mysql | maven | node 二、代码及数据库 三、功能介绍 01. web端-注册 02. web端-登录 03. web端-系统主页1 04. web端-系统主页2 05. we…

【数据结构】2算法及分析

0 章节 &#xff11;&#xff0e;&#xff14;到1&#xff0e;&#xff15;小节。 掌握算法概念、特性、描述、算法性能时间复杂度和空间复杂度&#xff1b; 理解递归含义&#xff1f; 掌握实现递归的条件和时机&#xff1b; 应用简单递归问题的算法设计&#xff1b; 重点 算法…

【一起学Rust | Tauri2.0框架】基于 Rust 与 Tauri 2.0 框架实现软件开机自启

文章目录 前言 一、准备工作1.1 环境搭建1.2 创建 Tauri 项目1.3 添加依赖 二、实现开机自启的基本原理2.1 开机自启的基本概念2.2 Tauri 应用的生命周期 三、Windows 平台实现3.1 Windows 注册表机制3.2 实现步骤3.3 注意事项 四、Linux 平台实现4.1 Linux systemd 服务4.2 实…

一周热点-OpenAI 推出了 GPT-4.5,这可能是其最后一个非推理模型

在人工智能领域,大型语言模型一直是研究的热点。OpenAI 的 GPT 系列模型在自然语言处理方面取得了显著成就。GPT-4.5 是 OpenAI 在这一领域的又一力作,它在多个方面进行了升级和优化。 1 新模型的出现 GPT-4.5 目前作为研究预览版发布。与 OpenAI 最近的 o1 和 o3 模型不同,…

css中的浮动

在 CSS 中&#xff0c;浮动&#xff08;float&#xff09;是一种定位元素的方式&#xff0c;它允许元素脱离正常的文档流&#xff0c;并向左或向右移动&#xff0c;直到其边缘碰到包含块或者另一个浮动元素的边缘。下面从多个方面详细介绍 CSS 浮动&#xff1a; 一&#xff0c…

element-plus中form表单组件的使用

1.如何让每个表单项对齐&#xff1f; 问题描述&#xff1a;如下图&#xff0c;每个表单项的输入框/下拉框/日期选择器是没有对齐的&#xff0c;我们希望它们纵向是对齐的。 解决方案&#xff1a;给el-form标签&#xff0c;加上label-width"100px"即可。意思就是给每个…

线性搜索算法

何时使用线性搜索算法&#xff1f; 当处理一个小数据集时。当搜索存储在连续内存中的数据集时。 线性搜索算法在什么情况下优于其他搜索算法&#xff1f; 当列表或数组未排序时&#xff0c;或者当输入的大小相对较小时&#xff0c;首选线性搜索算法。它易于实现&#xff0c;并…

踩坑记录:yolov5环境版本要求比较严苛?

在安装yolov5环境时&#xff0c;numpy安装失败报错metadata-generation-failed 报错如下&#xff1a; Collecting numpy1.18.5 (from -r /*****/yolov5-5.0/requirements.txt (line 5))Using cached https://pypi.tuna.tsinghua.edu.cn/packages/01/1b/d3ddcabd5817be02df0e6…

Java设计模式系列:单例模式的7种实现与适用场景

一、单例模式核心价值与实现原则 1. 使用场景 全局配置类(如数据库连接池)日志记录器Spring默认Bean作用域硬件设备访问(如打印机)2. 设计三原则 私有构造器:禁止外部实例化静态实例持有:全局唯一访问点延迟加载(可选):避免资源浪费二、七种单例实现方式深度解析 1.…

OpenManus-通过源码方式本地运行OpenManus,含踩坑及处理方案,chrome.exe位置修改

前言&#xff1a;最近 Manus 火得一塌糊涂啊&#xff0c;OpenManus 也一夜之间爆火&#xff0c;那么作为程序员应该来尝尝鲜 1、前期准备 FastGithub&#xff1a;如果有科学上网且能正常访问 github 则不需要下载此软件&#xff0c;此软件是提供国内直接访问 githubGit&#…

【最新】DeepSeek 实用集成工具有那些?

deepseek 系列github仓库地址 【主页】deepseek-aiDeepSeek-R1DeepSeek-V3DeepSeek-VL2【本文重点介绍】awesome-deepseek-integration 注意&#xff1a;以下内容来自awesome-deepseek-integration DeepSeek 实用集成&#xff08;awesome-deepseek-integration&#xff09; 将…