传输层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:域名解析协议

相关推荐
chian-ocean1 天前
深入 CANN:使用 `tbe-op` 构建自定义高性能算子
网络
中议视控1 天前
可编程网络中央控制系统主机通过红外发射棒控制空调电视等红外设备
网络·物联网·5g
数据安全科普王1 天前
打破中心枷锁:P2P网络如何用“去中心化”重构互联网通信
网络·去中心化·p2p
爱吃烤鸡翅的酸菜鱼1 天前
CANN ops-nn激活函数与池化算子深度解析
网络·开源·aigc
saber_andlibert1 天前
TCMalloc底层实现
java·前端·网络
飞凌嵌入式1 天前
用「EN 18031认证」通关欧盟,这张 “网络安全护照” 已就位
网络·安全·能源
Trouvaille ~1 天前
TCP Socket编程实战(三):线程池优化与TCP编程最佳实践
linux·运维·服务器·网络·c++·网络协议·tcp/ip
JoySSLLian1 天前
手把手教你安装免费SSL证书(附宝塔/Nginx/Apache配置教程)
网络·人工智能·网络协议·tcp/ip·nginx·apache·ssl
Zach_yuan1 天前
自定义协议:实现网络计算器
linux·服务器·开发语言·网络
猫头虎1 天前
如何解决 OpenClaw “Pairing required” 报错:两种官方解决方案详解
网络·windows·网络协议·macos·智能路由器·pip·scipy