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

相关推荐
feathered-feathered1 小时前
网络原理——应用层协议HTTP/HTTPS(重点较为突出)
java·网络·后端·网络协议·http·https
2501_938810111 小时前
什么IP 适用爬虫 采集相关业务
爬虫·网络协议·tcp/ip
MarkHD1 小时前
车辆TBOX科普 第51次 WebSocket实时通信与数据序列化:JSON vs Protobuf的深度实践
websocket·网络协议·json
杜大哥1 小时前
windows:如何检查出电脑IP和其它的电脑IP地址冲突?
网络·网络协议·tcp/ip
在外面要叫头哥1 小时前
计算机网络5层模型通俗详解:从“发快递”看网络传输
网络·计算机网络
老蒋新思维1 小时前
创客匠人峰会深度解析:创始人 IP 打造的 “情绪 + 技术” 双引擎
大数据·网络·人工智能·网络协议·tcp/ip·重构·创客匠人
Wokoo71 小时前
WebSocket :实时通信技术对比
网络·websocket·网络协议·http·信息与通信
galaxyffang1 小时前
WebSocket 和 Http 的核心区别
websocket·网络协议·计算机网络·http
“αβ”10 小时前
MySQL表的操作
linux·网络·数据库·c++·网络协议·mysql·https