计算机网络入门 -- TCP详解

计算机网络入门 – TCP详解

1.TCP协议

1.1 报文格式

alt text

  • 1.32位序号:该条TCP数据携带的起始序号。

  • 2.32位确认序号:期望对方发送数据从那个序号开始发送。

  • 3.4位首部长度:最大为0xF(15),指的是TCP头部长度。
    首部长度 = 4 位首部长度 ( D E C ) ∗ 4 首部长度 = 4位首部长度(DEC) \ast 4 首部长度=4位首部长度(DEC)4

  • 4.6个标志位:

    • URG:紧急标志位(直接越过发送缓冲区等待的数据优先传输到网络层,一般配合底下16位紧急指针使用)。
    • ACK:确认标志位。
    • PSH:发送数据标志位。
    • RST:重置连接标志位(当无法识别对方发来的连接请求时,会使用RST)。
    • SYN:发起连接标志位。
    • FIN:断开连接标志位。
  • 5.16位窗口大小:告知消息发送方,自己对消息的接收能力为多少,该值是动态变化的。

  • 6.16位校验和:校验数据在传输过程中是否失真。

  • 7.16位紧急指针:配合URG标志位发送带外数据。

  • 8.MSS:最大报文段长度

1.2 传输机制

1.2.1 确认应答(ACK)机制

alt text

TCP通过肯定的确认应答实现可靠数据传输,当发送端发出数据后会等待对方的确认应答,若有确认应答则数据发送成功,反正数据可能丢失。在一定时间内没有等到确认应答,发送端就认为发送数据已经丢失,并重新发送。因此,即使产生数据丢包,仍然能够保证数据传输到对方。

  • 传输时丢包:当发送端发出数据后未得到接收端确认,在认定数据丢失后发送端将重新发送数据。
  • 确认应答丢失:若此时接收端已接收到发送端的数据,但应答信息在传输过程中未到达发送端则会重新发送。

1.2.2 超时重传

重发超时指在重发数据之前,等待确认应答到来的那个特定时间间隔。若超过该时长仍未接收到应答信息,发送端将重新发送数据,以下时时间定义:TCP要求不论处在何种网络环境下都要提供高性能通信,并且无论网络拥堵情况发生何种变化,都必须保持这一特性。为此,它在每次发包时都会计算往返时间(Round Trip Time也叫RTT。是指报文段的往返时间。) 及其偏差(RTT时间波动的值、方差。有时也叫抖动。) 。将这个往返时间和偏差相加重发超时的时间,就是比这个总和要稍大一点的值。
R T O = R T T ( 上次 ) × i + R T T ( 上上次 ) × ( 1 − i ) RTO = RTT(上次) \times i + RTT(上上次) \times (1 - i) RTO=RTT(上次)×i+RTT(上上次)×(1i)

1.2.3 连接管理机制

即TCP连接时的三次握手和断开的四次挥手

1.2.4 滑动窗口机制

TCP以1个单位,每发一个段进行一次确认应答处理,保证数据传输可靠性,但缺点是包的往返时间越长则通信性能越低。为了解决传输效率低下,TCP引入窗口概念。即在往返时间较长的情况下,也能控制网络性能下降。确认信息不再以单个分段,而是以更大的单位进行确认时,转发时间将大幅缩短。简单来说就是当发送端主机发送一个段后不必要一直等待确认应答,而是继续发送。

alt text

滑动窗口在遇到数据丢包时处理方法如下:

  • 1.数据包已传给对方但ACK丢失

alt text

  • 2.传输的数据包直接丢失,或者说是某个报文段丢失的情况。

alt text

1.3 流量控制

发送端根据自己实际情况发送数据,但接收端可能收到一个毫无关系的数据包有可能会在处理其他问题上花费一些时间。因此在为这个数据包做其他处理时会消耗一些时间,甚至在高负载情况下无法接收任何数据,从而导致接收端将发送端数据放弃,出发重传机制,浪费流量。而TCP提供了一种可以让发送端根据接收端的实际接收能力控制发送的数据量的机制,即流量控制。
流量控制具体操作是接收端向发送端通知自己能够接收的数据大小,此时发送端就不会发送比该限度更大的数据。该限度为窗口大小。
TCP首部中有一个专门字段用于通知窗口大小。接收主机将自己可以接收的缓冲区大小放入该字段中发送给发送端。值越大说明网络吞吐量越大。
当接收端缓冲区数据溢出时,窗口大小就会改变,通知发送端。

alt text

1.4 拥塞控制

TCP虽然有流量控制,但在一开始就发送大量数据则会引发问题,因此TCP引入慢启动机制。即先发送少量数据,测试网络情况。当网络情况正常则在按照多大的速度传输

alt text

1.5 延迟应答机制

接收端若每次接收数据后都立即做出应答,则可能会返回一个比较小的窗口。当某个接收端以一个小窗口应答后,发送端会认为这是数据传输上限,则会降低传输速度和流量。为了避免这种事情,引入延迟应答机制。

  • 数量限制:每个N个数据包应答一次
  • 时间限制:超过最大延迟就应答一次

alt text

1.6 心跳机制

当客户端与服务端连接后可能会出现在很长一段时间内无任何数据传输的情况,此时服务端会定时向客户端发送一个心跳数据来确认客户端与服务端是否连接正常。该心跳数据会每隔75s发送一次,当发送10次后客户端无任何响应则视为客户端下线。

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

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

相关文章

谷粒商城实战笔记-37-前端基础-Vue-基本语法插件安装

文章目录 一,v-model1,双向绑定2,vue的双向绑定2.1 html元素上使用指令v-model2.2 model中声明对应属性2.3,验证view绑定modelmodel绑定view 完整代码 二,v-on1,指令简介2,在button按钮中添加v-…

rimraf快速删除node_modules方法

项目中,有时候会遇到下载依赖报错,然后想要删除node_modules再重新下载,但是有时候直接用yarn 或者npm install仍热不行,我们可以尽量用yran,因为npm 可能会自动下一些给一些包升级了,此时因为前面已经下过…

JVM:GraalVM

文章目录 一、介绍1、什么是GraalVM:2、GraalVM版本 二、两种使用模式 一、介绍 1、什么是GraalVM: GraalVM是Oracle官方推出的一款高性能JDK,使用它享受比OpenJDK或者OracleJDK更好的性能。GraalVM的官网地址:https://www.graa…

泛型新理解

1.创建三个类,并写好对应关系 package com.jmj.gulimall.study;public class People { }package com.jmj.gulimall.study;public class Student extends People{ }package com.jmj.gulimall.study;public class Teacher extends People{ }2.解释一下这三个方法 pub…

数据结构(稀疏数组)

简介 稀疏数组是一种数据结构,用于有效地存储和处理那些大多数元素都是零或者重复值的数组。在稀疏数组中,只有非零或非重复的元素会被存储,从而节省内存空间。 案例引入 假如想把下面这张表存入文件,我们会怎么做?…

【LeetCode】翻转二叉树

目录 一、题目二、解法完整代码 一、题目 给你一棵二叉树的根节点 root ,翻转这棵二叉树,并返回其根节点。 示例 1: 输入:root [4,2,7,1,3,6,9] 输出:[4,7,2,9,6,3,1] 示例 2: 输入:root…

php-fpm如何配置max_children参数

前言 略 php-fpm 资源耗尽 php-fpm 的子进程耗尽的时: 会导致 502 出现nginx 出现错误日志 2024/07/18 20:19:10 [crit] 36390#0: *1402471 connect() to unix:/tmp/php-cgi-81.sock failed (2: No such file or directory) while connecting to upstream, cli…

Spring Authorization Server实战

Spring Authorization Server实战 Spring Authorizatin Server Spring Authorizatin Server是一个框架,它提供了OAuth2.1和OpenID Connect 1.0规范以及其它相关规范的实现,它是基于Spring Security构建的 OAuth2.0协议介绍 OAuth是一个开放标准的授权…

使用docker swarm搭建ruoyi集群环境

整体目标 项目背景 领导给到了我一个客户,客户商业模式为成本制作,成本核算。其中涉及到大量涉密数据,且与我们现有产品几乎没有兼容点(我们是一套低代码的框架,客户有很多业务二开) 测试环境给到了我6台…

大模型学习笔记 - LLM模型架构

LLM 模型架构 LLM 模型架构 1. LLM 核心模型 Transformer2. 详细配置 2.1 归一化方法2.2 归一化模块位置2.3 激活函数2.4 位置编码 2.4.1 绝对位置编码2.4.2 相对位置编码2.4.3 旋转位置编码 RoPE2.4.4 ALiBi位置编码 2.5 注意力机制 2.5.1 完整自注意力机制2.5.2 稀疏注意力机…

ChatGPT实战100例 - (20) 如何玩转影刀RPA

文章目录 ChatGPT实战100例 - (20) 如何玩转影刀RPA背景需求需求分析与流程设计一、需求收集二、流程梳理三、可行性分析流程设计(详细步骤)具体步骤的影刀RPA实现流程图总结AIGC在影刀RPA中的使用总结其他RPA步骤中可能用到AIGC的地方展望总结ChatGPT实战100例 - (20) 如何玩…

LeYOLO, New Scalable and Efficient CNN Architecture for Object Detection

LeYOLO, New Scalable and Efficient CNN Architecture for Object Detection 论文链接:http://arxiv.org/abs/2406.14239 代码链接:https://github.com/LilianHollard/LeYOLO 一、介绍 本文关注基于FLOP的高效目标检测计算的神经网络架构设计选择&am…

【Vite】快速入门及其配置

概述 Vite是前端构建工具。vite 相较于webpack,vite采用了不同的运行方式: 开发时,并不对代码打包,而是直接采用ESM的方式来运行项目在项目打包部署时,使用 rollup 对项目进行打包除了速度外,vite使用起来也更加方便…

驱动程序在\device\raidport1 上检测到控制器错误

🏆本文收录于《CSDN问答解答》专栏,主要记录项目实战过程中的Bug之前因后果及提供真实有效的解决方案,希望能够助你一臂之力,帮你早日登顶实现财富自由🚀;同时,欢迎大家关注&&收藏&…

全新UI自助图文打印系统小程序源码/自助云打印机前后端源码

全新UI自助图文打印系统小程序源码,自助云打印机前后端源码。最新的自助图文打印系统和证件照云打印小程序源码采用了PHP作为后端开发语言,旨在为用户提供全面的自助打印服务。 这些服务覆盖了多种文件格式,包括文档、图片、表格等。除此之外…

pipeline:无题

这里写自定义目录标题 复盘我是如何做的撰写评审文档O-KR-KA任务网络图与计划资源需求 && 风险项资源需求风险项 其他 讨论、评审文档撰写评审纪要、结论 反思 复盘 目前工作中的一个现状是,在季度开始的时候需要自己思考方向、规划工作;可能还需…

手机接Usb hub再连接电脑下D+D-波形

🏆本文收录于《CSDN问答解答》专栏,主要记录项目实战过程中的Bug之前因后果及提供真实有效的解决方案,希望能够助你一臂之力,帮你早日登顶实现财富自由🚀;同时,欢迎大家关注&&收藏&…

医联体信息平台建设方案PPT(54页)

文章摘要: 医联体信息平台现状当前医联体信息平台存在脱离医疗业务建设的倾向,导致信息孤岛,业务协同困难。 建设存在的问题主要问题包括健康档案无法动态更新和共享,信息系统之间信息共享和协同不足。 医联体信息平台建设方案方…

堆及堆的管理

堆的作用 堆是用来作为存储空间的 堆的创建与释放 分离的空闲空间的管理建议使用链表 在链表中指定空间大小及下一块空闲链表

2.3 大模型硬件基础:AI芯片(上篇) —— 《带你自学大语言模型》系列

本系列目录 《带你自学大语言模型》系列部分目录及计划,完整版目录见:带你自学大语言模型系列 —— 前言 第一部分 走进大语言模型(科普向) 第一章 走进大语言模型 1.1 从图灵机到GPT,人工智能经历了什么&#xff1…