UDP/TCP协议全解

article/2025/7/30 16:39:35

目录

一. UDP协议

1.UDP协议概念

2.UDP数据报格式

3.UDP协议差错控制

二. TCP协议

1.TCP协议概念

2.三次握手与四次挥手

3.TCP报文段格式(重点)

4.流量控制

5.拥塞控制


一. UDP协议

1.UDP协议概念

当应用层的进程1要向进程2传输报文,会将报文转给传输层处理;UDP会在报文前加上一个UDP首部(只占8字节),组成一个UDP数据包;最后再发到网络层,网络层再加上一个IPV4首部,根据这个首部信息找到目的地址;然后主机B收到这个IP数据包以后,进行逆操作


  • UDP首部很小,只占8B
  • UDP会拒绝过大的报文,因为它每次只能传输一个完整报文,不支持拆分、重装
  • UDP无连接、不可靠的(无报错确认机制,由应用层完成),不支持拥塞控制(路由器过载运作,传输数据报的速度不会慢下来)
  • UDP支持一对一+一对多(一对一封装成单播IP数据报,一对多封装成广播、多播IP数据报)

UDP一对一的方法与TCP相同

一对多是通过目的IP为 255.255.255.255 (广播IP,往目的网络所有的主机进行数据发送),然后后面加上一整个UDP协议下的数据报。UDP能支持广播很重要的一个原因在于:不需要进行拆分、重装,可以一次性全部传输完;同时,UDP是通过UDP首部中设置目的端口号来寻找目标主机,然后对目的端口的所有主机进行数据传输(TCP也是通过目的端口寻找目标主机,但找到一众目标主机后只能与其中之一进行连接),所以可以通过端口号一次性找到多台目标主机(如下图,主机A要向目的网络的所有端口为711的主机发送消息)

2.UDP数据报格式

UDP长度:声明数据报大小,固定只有16比特(即65535字节,2^15+2^14+……+2^0 = 65535);由于一个IP数据报可以运输的最大数据量是65515字节,因此UDP协议下的数据报最大只能是65535字节;UDP长度应该是UDP首部+报文的大小,不是单指报文大小

UDP校验和:由发送方计算并输入,接收方检验是否错误,全0代表无需校验

3.UDP协议差错控制

检验信息的生成与使用:若有32bit数据信息,相加以后逐位取反;此时数据相加的结果,与取反以后的检验和相加,应该正好为全1(数据为0的地方,检验和肯定为1;数据为1的地方,检验和肯定为0);接收方只要看检验和与数据相加以后是否为全1,如果为全1就代表没出差错;如果最高位产生进位,就需要“回卷”加到最低位

UPD检验的过程:生成检验和前,先在UDP首部前生成一个伪首部;把伪首部、UDP首部与数据部分分以16bit为一组,进行检验和生成;生成了以后去除掉伪首部,通过网络层传输以后,接收方接受了以后也需要生成伪首部,然后判断相加是否为1(具体流程如下图)

IP协议的首部检验和方法与UDP大致相同,只是IP检验和数据部分不参与,UDP检验和要将数据部分也算上;同时,IP进行校验和时不需要添加伪首部

二. TCP协议

1.TCP协议概念

UDP与TCP之别

TCP首部很大且大小可变,要有20字节~60字节;TCP可以对报文进行分组、重装传输,因此可以传输大的报文(类比成分组交换);TCP需要连接(类似于电路交换),且会发送接受成功、接受错误信息 -> 可靠,并且能够进行流量控制,并且只能一对一;TCP传输内容叫做报文段(面向字节流),UDP传输内容叫做数据报(面向整体报文)


TCP特点

n个TCP报文段可能乱序到达接收方,但TCP协议会按序向应用层递交;每次建立TCP连接以后,可以双向传输多个报文;MSS是由通信双方决定的报文段最大段长,TCP不要求报文段满载,只要别超过MSS即可

2.三次握手与四次挥手

注:挥手操作A、B两端谁先结束,谁先释放连接


三次握手

握手1、握手2不能携带数据,但是仍要消耗一个序号;握手3可以携带数据,不携带数据就不消耗序号,此处的序号指的是ack、seq后面的数字;接收端的序号与发送端的区号是可以不一样的,可以理解成两端发送的数据不一样

客户端、服务器进程TCP状态变化如下图所示


四次挥手

挥手1、挥手3即使不携带数据,也要消耗1个序号;挥手2可以携带数据,挥手4不可以携带数据

客户端、服务器进程TCP状态变化如下图所示。MSL指的是最长报文段寿命,1MSL指800ms,2MSL代表1600ms过后客户端才会真正关闭连接

3.TCP报文段格式(重点)

序号(seq):用于标记数据部分第一个字节在原始字节流的位置,起始序号由发送方自己设置(不一定从0开始)

确认号(ack或者ack_seq):用于反馈,表示序号在该确认号之前的所有字节都已正确收到;ACK = 0 时,ack 无效,ACK = 1 时,ack 有效;只有第一次挥手时,ack会是无效的,其他情况下ack都应该有效(若无效则说明出现了差错,例如报文段丢失)

数据偏移(data offset):表示TCP首部长度,以4字节为单位(比如现在的tcp首部只有3字节,那么此时就需要通过后面的填充部分加上1字节),表示形式是字节实际存储用的是比特位

保留:暂时没用,通常全设置为0

填充:被用来解决数据偏移问题,凑足4字节的整数倍

URG(紧急位):只占1bit,为1时表示是紧急数据要尽快插队发送;当该位为1时,会让紧急指针有效,紧急指针存放了紧急数据专用序号

PSH(推送位):为1时希望接收方尽快回复

RST(复位位):为1时表示出现严重差错(例如主机崩溃),必须释放连接;或者需要拒绝一个非法报文段(例如恶意的黑客攻击)

SYN(同步位):为1时表示这是一个连接请求或连接接受报文;只在握手1、握手2中,SYN = 1

FIN(终止位):为1时表示请求释放连接报文;只在挥手1、挥手3中,FIN = 1

窗口(rwnd或者rcvwnd):用作流量控制,假设现在的接受缓冲区还剩下500B空间,那么此时的rwnd = 500(即接收方还能接受多少数据)

检验和:和UDP原理一样

选项(长度可变):协商决定了在握手1、握手2当中,MSS字段大小多少

4.流量控制

窗口大小与MSS大小不一的原因:接受发送的端口,主机的处理能力不一样

如果缓冲区域大小为3000字节,那么滑动窗口大小为3000字节,当被占满以后处理了2000字节,此时的滑动窗口大小为2000字节。不同的滑动窗口大小,在回复信息时的rwnd大小都不一样,同时为0时的ACK主要是告诉发送方接受成功。

5.拥塞控制

cwnd是针对发送方而言的,一个限制性的滑动窗口

超时:如果发送了当前窗口大小的数据量,在规定的时间内没有接收到接收方发来的确认好,那么就会超时重传;发送超时重传以后,慢开始的下限值会变成当前滑动窗口的一半大小,然后又开始进入到慢开始阶段

3-ACK:收到了一条数据的三次确认信息,说明有该数据发送失败了;此时停止发送,然后将传输失败的数据快重传;因为并非由于数据过多而导致的传输失败,因此不用进行慢开始;变一半同超时


http://www.hkcw.cn/article/vaupuxQJkX.shtml

相关文章

话题通信之python实现

在机器人操作系统(ROS)中,话题通信是一种常见的通信方式,它允许不同的节点之间通过主题进行数据交换。本文将介绍如何使用Python实现ROS话题通信,包括发布者和订阅者的编写。这种方法与使用C实现类似,但Pyt…

中国高分辨率高质量地面NO2数据集(2008-2023)

时间分辨率:日空间分辨率:1km - 10km共享方式:开放获取数据大小:15.36 GB数据时间范围:2008-01-01 — 2023-12-31元数据更新时间:2024-08-19 数据集摘要 ChinaHighNO2数据集是中国高分辨率高质量近地表空气…

射频通信概述

系列文章目录 提示:这里可以添加系列文章的所有文章的目录,目录需要自己手动添加 例如:第一章 Python 机器学习入门之pandas的使用 提示:写完文章后,目录可以自动生成,如何生成可参考右边的帮助文档 文章目…

设置堆空间的最大值(-Xmx)应该要考虑哪些因素?

需要根据系统的配置来确定,要给操作系统和JVM其他内存区域(栈、方法区)留下一定的剩余空间。推荐配置系统或容器里可用内存的70%~80%最好。 假设物理内存是8G,设置多大堆内存比较合适? 系统有8G物理内存,系统自己可能会…

wordpress免费主题网站

这是一款WordPress主题,由jianzhanpress开发,可以免费下载。专为中小微企业设计,提供专业的网站建设、网站运营维护、网站托管和网站优化等服务。主题设计简约、现代,适合多种行业需求。 主要特点: 多样化展示&#…

SGLang 无法正常部署

1. 考虑 torch 版本 与 SGLang 不兼容: -> Python环境中的包被更新(如torch, deepspeed, transformers等)导致不兼容 - 参考:Exception: Capture CUDA graph failed: CUDA error: out of memory-CSDN博客 # 虽然锁定了 sg…

【拓扑排序】P6560 [SBCOI2020] 时光的流逝|普及+

本文涉及知识点 C图论 拓扑排序 P6560 [SBCOI2020] 时光的流逝 题目背景 时间一分一秒的过着,伴随着雪一同消融在了这个冬天, 或许,要是时光能停留在这一刻,该有多好啊。 … “这是…我在这个小镇的最后一个冬天了吧。” “嗯…

第13讲、Odoo 18 配置文件(odoo.conf)详细解读

1. 概述 Odoo 配置文件(odoo.conf)是管理 Odoo 服务器行为的核心工具,涵盖了网络、安全、数据库、性能等多方面的关键参数。本文档系统梳理 Odoo 18 配置文件的主要参数,结合实际应用场景,提供权威的配置建议与最佳实…

“大巴黎”欧冠夺冠引发法国多地骚乱

法甲球队巴黎圣日耳曼5月31日晚赢得欧冠联赛冠军奖杯,法国多地球迷彻夜庆祝。据法国内政部消息,狂欢夜有559人因滋事被捕,并发生两起命案。据法国媒体援引法国内政部等信源,在巴黎,一名20岁男子骑摩托车与汽车相撞,导致重伤不治身亡。在法国西南部城市达克斯,一名17岁未…

马斯克最新发声:不想为美政府所做的一切承担责任

当地时间6月1日,美国企业家埃隆马斯克当日在接受美国哥伦比亚广播公司的采访时表示,他不想公开反对美国政府,但也不想为政府所做的一切承担责任。马斯克在采访中表示,他所领导的“政府效率部”成了一切的替罪羊,所有的裁员无论是真是假都被怪罪到了“政府效率部”的头上。…

c++ QicsTable使用实例

效果图&#xff1a; #include <QicsTable.h> #include <QicsDataModelDefault.h> #include <QVBoxLayout> Demo1::Demo1(QWidget *parent) : QWidget(parent) { ui.setupUi(this); const int numRows 10; const int numCols 5; // create th…

俄乌第二轮会谈前夕 飞出数只 “黑天鹅”

俄乌第二轮谈判将于6月2日举行。根据土耳其外交部在1日晚间发布消息,本次会谈将于当地时间2日13时在伊斯坦布尔的契拉昂宫举行。截至目前,俄乌双方均就这次谈判各自的立场和方向做出了一定说明。但就在本次俄乌会谈前夕,多起“黑天鹅”事件却接连发生。△伊斯坦布尔的契拉昂…

内存马mama

一、Tomcat三种内存马 首先了解下tomcat的三种内存马的原理和简单实用 filter型内存马 Tomcat filter注册流程 FilterDefs&#xff1a;存放FilterDef的数组 &#xff0c;FilterDef 中存储着我们过滤器名&#xff0c;过滤器实例&#xff0c;作用 url 等基本信息 FilterConf…

PySide6 GUI 学习笔记——常用类及控件使用方法(地址类QUrl)

文章目录 地址类QUrl主要功能URL 格式介绍常见 scheme&#xff08;协议&#xff09;类型QUrl 类常用方法常用方法示例典型应用场景 地址类QUrl QUrl 是 PySide6.QtCore 模块中的一个类&#xff0c;用于处理和操作 URL&#xff08;统一资源定位符&#xff09;。它可以解析、构建…

DAY40 训练和测试

昨天我们介绍了图像数据的格式以及模型定义的过程&#xff0c;发现和之前结构化数据的略有不同&#xff0c;主要差异体现在2处 模型定义的时候需要展平图像由于数据过大&#xff0c;需要将数据集进行分批次处理&#xff0c;这往往涉及到了dataset和dataloader来规范代码的组织…

彻底理解Spring三级缓存机制

文章目录 前言一、Spring解决循环依赖时&#xff0c;为什么要使用三级缓存&#xff1f; 前言 Spring解决循环依赖的手段&#xff0c;是通过三级缓存&#xff1a; singletonObjects&#xff1a;存放所有生命周期完整的单例对象。&#xff08;一级缓存&#xff09;earlySingleto…

Diffusion Planner:扩散模型重塑自动驾驶路径规划(ICLR‘25)

1. 概述 2025年2月14日&#xff0c;清华大学AIR智能产业研究院联合毫末智行、中科院自动化所和香港中文大学团队&#xff0c;在ICLR 2025会议上发布了Diffusion Planner——一种创新性的基于Diffusion Transformer的自动驾驶规划模型架构。该系统联合建模周车运动预测与自车行…

财管5-投资项目的评价指标现金流量构成

一、投资项目评价指标 独立项目评价指标包括净现值&#xff08;NPV&#xff09;、现值指数&#xff08;PI&#xff09;、内含报酬率&#xff08;IRR&#xff09;、回收期&#xff08;PP&#xff09;、会计报酬率&#xff1b; 1、净现值 计算NPV 未来现金流量的现值 - 原始投…

【Bluedroid】蓝牙启动之 l2c_init 源码解析

蓝牙 L2CAP&#xff08;逻辑链路控制和适配协议&#xff09;层是蓝牙协议栈的核心传输层&#xff0c;负责为上层协议&#xff08;如 ATT、SMP、GATT&#xff09;提供逻辑通道、服务路由和流量控制等关键功能。本文围绕 L2CAP 层的五大核心数据结构&#xff08;全局控制块tL2C_C…

NACOS 配置中心--数据隔离

1.实现效果 名称空间 -- 区分 多套环境 group 分组 -- 区分多种微服务 data id 数据集 -- 区分多种配置 2.新建命名空间 3.创建 group 和 data id 同逻辑 创建 test 和prod 环境配置 5.yml文件配置进行映射 server:port: 8000 spring:config:import: # 映射data id 和gro…