【计算机网络】传输层UDP协议

article/2025/7/18 15:43:49

🔥个人主页🔥:孤寂大仙V
🌈收录专栏🌈:计算机网络
🌹往期回顾🌹: 【计算机网络】应用层协议Http——构建Http服务服务器
🔖流水不争,争的是滔滔不息


  • 一、UDP协议
  • 二、UDP特点
    • 面向数据报
  • 三、UDP缓冲区
  • 四、基于UDP的应用层协议
  • 五、报文理解

一、UDP协议

UDP(User Datagram Protocol,用户数据报协议)是一种无连接的传输层协议,提供简单的、不可靠的数据传输服务。与TCP不同,UDP不保证数据包的顺序、可靠性或流量控制,但具有低延迟和高效率的特点,适用于实时性要求高但允许少量丢包的应用场景。

UDP协议端格式
在这里插入图片描述
UDP 报文其实很简单,它的格式是 “定长报头 + 不定长数据”。如图上面8字节是报头大小,下面数据是有效载荷。UDP报头是定长报头,所以每个报文交付给上层报头都是确定的。UDP报文分离的时候,直接把定长的报头和有效载荷分离就好了,分用根据目的端口号去完成。UDP报文和报文之间都有有边界的,所以不用像TCP传输那样还要自定义协议区区分报头。16位源端口号是表示报文是从哪发的,16位目的端口号是表示报文要发到哪里。端口号设计为16位的,是因为内核协议是16位的。报头是固定的,每个报文的有效载荷能和报头分明的区分,且报文和报文之间有边界,这就是用户数据报最大的特点。16 位 UDP 长度, 表示整个数据报(UDP 首部+UDP 数据)的最大长度;如果校验和出错, 就会直接丢弃;

为什么说UDP简单?
UDP和TCP有一个最大的不同:UDP是有“边界”的协议,每一个UDP报文本身就是独立的一块
内核收到一个UDP报文,直接把8字节头部剥掉,剩下的数据送到应用层就行。
每一个recvfrom()调用,只会收到一个完整的UDP报文(不会拆开,也不会合并)。
不像TCP:TCP是“流”,没有边界,一个包可能拆成多个recv才收完,或者多个包粘在一起。所以TCP应用层必须“自己想办法分包”,比如用自定义协议。

二、UDP特点

UDP 传输的过程类似于寄信。

  • 无连接: 知道对端的 IP 和端口号就直接进行传输, 不需要建立连接;
  • 不可靠: 没有确认机制, 没有重传机制; 如果因为网络故障该段无法发到对方,UDP 协议层也不会给应用层返回任何错误信息;
  • 面向数据报: 不能够灵活的控制读写数据的次数和数量;

面向数据报

应用层交给 UDP 多长的报文, UDP 原样发送, 既不会拆分, 也不会合并;
用 UDP 传输 100 个字节的数据:如果发送端调用一次 sendto, 发送 100 个字节, 那么接收端也必须调用对应的一次 recvfrom, 接收 100 个字节; 而不能循环调用 10 次 recvfrom, 每次接收 10 个字节。

三、UDP缓冲区

在这里插入图片描述
UDP 没有真正意义上的 发送缓冲区. 调用 sendto 会直接交给内核, 由内核将数据传给网络层协议进行后续的传输动作;
UDP 具有接收缓冲区. 但是这个接收缓冲区不能保证收到的 UDP 报的顺序和发送 UDP 报的顺序一致; 如果缓冲区满了, 再到达的 UDP 数据就会被丢弃;
UDP 的 socket 既能读, 也能写, 这个概念叫做 全双工

因为UDP没有发送缓冲区,所以如果报文在网络传输的过程中丢包了,UDP 本身是“无连接 + 不可靠传输协议”,它不会确认你发出去了没,也不会重传,如果在网络中丢了,那就真的丢了,服务器一无所知。

如果应用层正在进行报文的解析,不会影响OS从网络中读取报文

UDP使用注意事项
我们注意到, UDP 协议首部中有一个 16 位的最大长度. 也就是说一个 UDP 能传输的数据最大长度是 64K(包含 UDP 首部).。
然而 64K 在当今的互联网环境下, 是一个非常小的数字,如果我们需要传输的数据超过 64K, 就需要在应用层手动的分包, 多次发送, 并在接收端手动拼装。

四、基于UDP的应用层协议

  • DNS(Domain Name System)
    DNS用于将域名解析为IP地址。由于查询通常只需一次请求-响应,UDP的轻量特性使其成为首选。默认使用端口53。
  • DHCP(Dynamic Host Configuration Protocol)
    DHCP用于自动分配IP地址。UDP的广播和多播支持使其适合局域网内的地址分配。客户端使用端口68,服务器使用端口67。
  • SNMP(Simple Network Management Protocol)
    SNMP用于网络设备监控和管理。UDP的简单性适合频繁的监控数据交换。默认使用端口161(查询)和162(陷阱)。
  • TFTP(Trivial File Transfer Protocol)
    TFTP是简单的文件传输协议,常用于网络引导或设备固件更新。使用UDP端口69,实现比FTP更轻量。
  • QUIC(Quick UDP Internet Connections)
    QUIC是Google开发的传输协议,基于UDP实现类似TCP的可靠性,但减少握手延迟。HTTP/3基于QUIC,提升Web性能。
  • VoIP(Voice over IP)
    语音通话协议如RTP(Real-time Transport Protocol)通常基于UDP。实时性要求高,少量丢包对语音质量影响较小。

五、报文理解

Linux sk_buff源码

struct sk_buff {union {struct {struct sk_buff *next;struct sk_buff *prev;union {struct net_device *dev;unsigned long dev_scratch;};};struct rb_node rbnode; // 用于红黑树};union {struct sock *sk;int ip_defrag_offset;};char cb[48]; // 控制缓冲区,协议层私有数据unsigned long _skb_refdst;unsigned int len, data_len;__u16 mac_len, hdr_len;__u16 queue_mapping;__u8 cloned:1, nohdr:1, fclone:2, peeked:1, head_frag:1;__u8 pfmemalloc:1, pp_recycle:1;__u16 tc_index; // 流量控制索引__u16 transport_header;__u16 network_header;__u16 mac_header;__u32 headers_end[0];void (*destructor)(struct sk_buff *skb);struct nf_conntrack *nfct;unsigned long nfct_reasm;__u32 secmark;unsigned int mark;__u16 vlan_proto;__u16 vlan_tci;union {__u32 inner_network_header;__u32 inner_network_header_offset;};__u32 inner_transport_header;__be16 protocol;__u16 transport_header_was;__u8 encapsulation:1;// 更多字段...unsigned char *head, *data, *tail, *end;
};

在这里插入图片描述
在操作系统内部,可能会同时存在大量的报文,操作系统必须管理这些报文。引入sk_buff(Socket Buffer)是 Linux 内核网络协议栈中 收发数据的核心结构体,每当有网络数据要处理,内核就会分配一个 sk_buff。

skb->head, skb->data, skb->tail, skb->end 是sk_buff内的指针。

  • skb->head:指向整个缓冲区的起始位置(分配的整块内存)
  • skb->data:指向有效数据的起始位置(比如 IP 头部开始)
  • skb->tail:指向有效数据的结尾(可以向后追加数据)
  • skb->end:指向缓冲区结尾(表示最多能写到哪)

所谓封装和解包,本质就是移动data指针在缓冲区中指向。

我们把data和tail想成一个"动态窗口",当我们的报完往下层协议封装就要往前移动data指针,封装报头,当往后移动tail指针的时候是添加新的数据。


发送过程:从上层到下层
调用send()或者write()发送数据,数据经历了用户态->内核态->网络层多次加工封装。
发送数据,数据进入内核socket buffer,内核分配sk_buff,并把数据填进去(通常从skb->tail开始)。进去TCP层,加上TCP报头skb->tail往前移动数据跟在TCP头后面,设置TCP序号、校验和等。进入IP层。加上IP层报头,设置源IP、目的IP等。进入数据链路层加MAC头,设置目标MAC、源MAC等。最后整个数据包都集中在skb->data和skb->tail之间->DMA拷贝给网卡发送过去。
接收过程:从底层到上层
网卡收到数据,触发中断。驱动将数据拷贝到sk_buff。skb->data指向以太网头部。一层一层"剥皮"去掉报头。最后skb->data指向payload(应用层数据)上交给socket buffer,再wake up用户进程接收。

sk_buff 就是内核网络协议栈用来“托运数据”的容器,skb->data 是快递包裹的“当前开箱点”,从 TCP 到 IP 到 MAC,每一层往前预留一段头,然后下发出去。


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

相关文章

day40python打卡

知识点回顾: 彩色和灰度图片测试和训练的规范写法:封装在函数中展平操作:除第一个维度batchsize外全部展平dropout操作:训练阶段随机丢弃神经元,测试阶段eval模式关闭dropout 作业:仔细学习下测试和训练代码…

2022-2023-2-移动机器人设计与实践-期末B

2022-2023-2-移动机器人设计与实践-期末A-CSDN博客 本文介绍了《移动机器人设计与实践》课程期末考试试卷B卷的内容与参考答案。试卷包含分析题、设计题、实践题和编程题四部分,总分100分。分析题考察学生对空中、水面和地上三种移动机器人模型运动机制及应用场景的…

DM8部分函数的功能分别举例说明

DM8部分函数的功能分别举例说明 1 环境说明2 函数功能使用示例2.1 AVG OVER2.2 COUNT OVER2.3 MIN OVER,MAX OVER,SUM OVER2.4 DENSE_RANK2.5 ROW_NUMBER2.6 FIRST2.7 LAG2.8 WM_CONCAT 3 更多达梦数据库全方位指南:安装 优化 与实战教程 1 环境说明 Cp…

大语言模型 24 - MCP 自动操作 提高模型上下文能力 Cursor + Sequential Thinking Server Memory

点一下关注吧!!!非常感谢!!持续更新!!! Java篇: MyBatis 更新完毕目前开始更新 Spring,一起深入浅出! 大数据篇 300: Hadoop&…

【多线程初阶】线程状态 线程安全

文章目录 1.线程状态线程的状态及状态转移 2.多线程带来的风险 - 线程安全(重点)线程安全问题产生的原因如何解决线程安全问题 1.线程状态 EE的第一篇总览中有提到过 进程的状态 1.就绪 2.阻塞 这都是从操作系统的视角看待的 Java线程也是对操作系统线程的封装,针对状态这里…

Python 序列的修改、散列和切 片(Vector类第4版:散列和快速等值 测试)

Vector类第4版:散列和快速等值测试 我们要再次实现__hash__ 方法。加上现有的__eq__ 方法,这会把 Vector 实例变成可散列的对象。 示例 9-8 中的__hash__ 方法简单地计算 hash(self.x) ^ hash(self.y)。这一次,我们要使用^(异或…

ai姿势项目

链接:https://pan.baidu.com/s/1dGSt7wEk8w6O7zlgme3CUQ?pwd=x60y 提取码:x60y --来自百度网盘超级会员V2的分享 配置环境 conda create -n 环境名称 python=3.8conda activate 环境名称 如果你运行程序的话会报错 ModuleNotFoundError: No module named mediapipe 进…

LoRA:高效微调预训练模型的利器

LoRA(Low-Rank Adaptation) 的思想:冻结预训练模型权重,将可训练的低秩分解矩阵注入到Transformer架构的每一层(也可单独配置某一层)中, 从而大大减少在下游任务的可训练参数量。 核心原理 对于预训练权重矩阵 ,LoRA限制了其更新…

越界检测算法AI智能分析网关V4打造多场景化的应用解决方案

一、方案概述 随着社会发展,传统安防系统在复杂环境下暴露出误报率高、响应慢等短板。AI智能分析网关V4依托先进算法与强大算力,实现周界区域精准监测与智能分析,显著提升入侵防范效能。本方案通过部署该网关及其越界检测功能,为…

使用SkiaSharp打造专业级12导联心电图查看器:性能与美观兼具的可视化实践

前言 欢迎关注dotnet研习社,今天我们研究的Google Skia图形库的.NET绑定SkiaSharp图形库。 在医疗软件开发领域,心电图(ECG)数据的可视化是一个既有挑战性又极其重要的任务。作为开发者,我们需要创建既专业又直观的界面来展示复杂的生物医学…

24位高精度数据采集卡NET8860音频振动信号采集监测满足自动化测试应用现场的多样化需求

NET8860 高分辨率数据采集卡技术解析 阿尔泰科技的NET8860是一款高性能数据采集卡,具备8路同步模拟输入通道和24bit分辨率,适用于高精度信号采集场景。其输入量程覆盖10V、5V、2V、1V,采样速率高达256KS/s,能够满足多种工业与科研…

2025年05月30日Github流行趋势

项目名称:agenticSeek 项目地址url:https://github.com/Fosowl/agenticSeek项目语言:Python历史star数:13040今日star数:1864项目维护者:Fosowl, steveh8758, klimentij, ganeshnikhil, apps/copilot-pull-…

PCB设计实践(三十一)PCB设计中机械孔的合理设计与应用指南

一、机械孔的基本概念与分类 机械孔是PCB设计中用于实现机械固定、结构支撑、散热及电气连接的关键结构元件,其分类基于功能特性、制造工艺和应用场景的差异,主要分为以下几类: 1. 金属化机械孔 通过电镀工艺在孔内壁形成导电层,…

TC/BC/OC P2P/E2E有啥区别?-PTP协议基础概念介绍

前言 时间同步网络中的每个节点,都被称为时钟,PTP协议定义了三种基本时钟节点。本文将介绍这三种类型的时钟,以及gPTP在同步机制上与其他机制的区别 本系列文章将由浅入深的带你了解gPTP,欢迎关注 时钟类型 在PTP中我们将各节…

五.MySQL表的约束

1.not null空属性 和 default缺省值 两个值:null(默认的)和not null(不为空) 元素可以分为两类 1.not null 不能为空的,这种没有默认default 要手动设定,我们必须插入数据而且不能为NULL。但我们插入数据有两种方式 1.…

4.Haproxy搭建Web群集

一.案例分析 1.案例概述 Haproxy是目前比较流行的一种群集调度工具,同类群集调度工具有很多,包括LVS、Nginx,LVS性能最好,但是搭建相对复杂;Nginx的upstream模块支持群集功能,但是对群集节点健康检查功能…

NewsNow:免费好用的实时新闻聚合平台,让信息获取更优雅(深度解析、部署攻略)

名人说:博观而约取,厚积而薄发。——苏轼《稼说送张琥》 创作者:Code_流苏(CSDN)(一个喜欢古诗词和编程的Coder😊) 目录 一、NewsNow项目概览1. 项目核心亮点2. 技术架构特点 二、核心功能深度解析1. 智能新…

论文阅读笔记——FLOW MATCHING FOR GENERATIVE MODELING

Flow Matching 论文 扩散模型:根据中心极限定理,对原始图像不断加高斯噪声,最终将原始信号破坏为近似的标准正态分布。这其中每一步都构造为条件高斯分布,形成离散的马尔科夫链。再通过逐步去噪得到原始图像。 Flow matching 采取…

【leetcode】02.07. 链表相交

链表相交 题目代码1. 计算两个链表的长度2. 双指针 题目 02.07. 链表相交 给你两个单链表的头节点 headA 和 headB ,请你找出并返回两个单链表相交的起始节点。如果两个链表没有交点,返回 null 。 图示两个链表在节点 c1 开始相交: 代码 …

文字转图片的字符画生成工具

软件介绍 今天要介绍的这款软件可以将文字转换成图片的排列形式,非常适合需要将文字图形化的场景,建议有需要的朋友收藏。 软件名称与用途 这款软件名为《字符画大师》,是一款在网吧等场所非常流行的聊天辅助工具,其主要功能就…