传输层UDP

一、UDP的特点:

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

• 无连接:知道对端的IP和端口号就直接进行传输,不需要建立连接。

• 不可靠:没有确认机制,没有重传机制,如果因为网络故障该段无法发到对方,UDP协议层也不会给应用层返回任何错误信息。

• 面向数据报:不能够灵活的控制读写数据的次数和数量。

二、面向数据报:

应用层交给UDP多长的报文,UDP原样发送,既不会拆分,也不会合并,用UDP传输100个字节的数据。

• 如果发送端调用一次sendto,发送100个字节,那么接收端也必须调用对应的一次recvfrom,接收100个字节,而不能循环调用10次recvfrom,每次接收10个字节。

UDP帧格式:

udp凭什么叫用户数据报?报文和报文之间都是有边界的。

UDP采用8字节定长报头,收到报文直接从头部提取8字节就是它的报头,根据目的端口号交给上层。

在应用层里的数据都会序列化成字节流,然后把报文交给下一层,要交给下一层就得添加报头,添加udp报头,填写16位源端口,填写16位目的端口,16位UDP长度代表整个报文长度,16位UDP校验和用于校验,不成功丢弃。

源ip、源端口、目标ip、目标端口、协议号这样一个五元组来标识通信。

tail指向应用层获取的数据,每向下传一层,data指针就继续往上移,传到传输层,data指针指向协议头,所谓的封装和解包,本质是data指针在缓冲区的移动。data指针+-对应层的协议长度。

报文的理解:存在许许多多的报文,需要先描述再组织

三、UDP缓冲区:

接口从缓冲区拷贝数据

• UDP没有真正意义上的发送缓冲区,调用sendto会直接交给内核,由内核将数据传给网络层协议进行后续的传输动作。

• UDP具有接收缓冲区,但是这个接收缓冲区不能保证收到的UDP报的顺序和发送UDP报的顺序一致,如果缓冲区满了,再到达的UDP数据就会被丢弃。

• 应用层给UDP多长的报文UDP就发送多长的报文,既不会拆分也不会合并。

四、基于UDP的应用层协议:

• NFS:网络文件系统

• TFTP:简单文件传输协议

• DHCP:动态主机配置协议

• BOOTP:启动协议(用于无盘设备启动)

• DNS:域名解析协议

相关推荐
云布道师13 小时前
阿里云 Tablestore 为 Hermes Agent 构建记忆系统最佳实践
网络·人工智能·阿里云
雨浓YN13 小时前
GKMLT通讯工具箱(WPF MVVM) - 02-Modbus RTU 与 TCP 报文格式、原理与CRC校验
网络·网络协议·tcp/ip
雨浓YN14 小时前
GKMLT通讯工具箱(WPF MVVM) - 01-网口/串口通讯与 ModBus RTU/TCP
网络·网络协议·tcp/ip
志栋智能16 小时前
运维超自动化:构建弹性IT架构的关键支撑
运维·服务器·网络·人工智能·架构·自动化
网安情报局1 天前
除了 CDN,DDoS 攻击还有哪些更有效的防护方式?
网络
Promise微笑1 天前
2026年国产替代油介损测试仪:油介损全场景解决方案与技术演进
大数据·网络·人工智能
AnalogElectronic1 天前
linux 测试网络和端口是否连通的命令详解
linux·网络·php
Rust研习社1 天前
使用 Axum 构建高性能异步 Web 服务
开发语言·前端·网络·后端·http·rust
灰子学技术1 天前
Envoy HTTP 流量层面的 Metric 指标分析
网络·网络协议·http
上海云盾-小余1 天前
海外恶意 UDP 攻击溯源:分层封禁策略与业务兼容平衡方案
网络·网络协议·udp