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

相关推荐
知乎的哥廷根数学学派2 小时前
基于数据驱动的自适应正交小波基优化算法(Python)
开发语言·网络·人工智能·pytorch·python·深度学习·算法
非凡ghost2 小时前
Wireshark中文版(网络抓包工具)
网络·windows·学习·测试工具·wireshark·软件需求
科技块儿3 小时前
使用强大的离线IP地址定位库IP数据云获取数据信息
网络·tcp/ip·php
上海云盾-高防顾问4 小时前
筑牢网络防线:境外恶意网址与IP防范指南
服务器·网络·安全
上海云盾-小余4 小时前
业务逻辑攻击是什么,如何有效进行防护
网络·安全
suzhou_speeder4 小时前
PoE 延长器:突破 PoE 距离限制,优化网络灵活部署方案
运维·网络·poe·poe交换机·poe延长器
wuk9985 小时前
基于C#与三菱PLC通过TCPIP实现MC协议通信示例
java·网络·c#
运维有小邓@5 小时前
Log360 的可扩展架构实践:常见场景
运维·网络·架构
热心市民R先生6 小时前
IGH EtherCAT 主站核心文件体系全解析:构成、区别与运维实践
运维·服务器·网络