UDP用户数据报协议
udp协议的特点
UDP传输的过程类似于寄信:
- 无连接:知道对端的IP和端口号就直接进行传输,不需要建立连接;
- 不可靠:没有确认机制, 没有重传机制;如果因为网络故障该段无法发到对方,UDP协议层也不会给应用层返回任何错误信息;
- 面向数据报:不能够灵活的控制读写数据的次数和数量;应用层交给UDP多长的报文,UDP加上报头后原样发送,既不会拆分,也不会合并;
udp协议端格式
注:udp所能传输的数据最大长度为64k,如果我们需要传输的数据超过64K,就需要在应用层进行手动的分包,多次发送,并在接收端手动拼装;
udp的缓冲区
- UDP没有真正意义上的发送缓冲区:调用sendto把数据直接交给内核,由内核将数据传给网络层协议进行后续的传输动作;
- UDP具有接收缓冲区:该接收缓冲区不能保证收到的UDP报的顺序和发送UDP报的顺序一致;如果缓冲区满了, 再到达的UDP数据就会被丢弃。
基于UDP的应用层协议
NFS:网络文件系统
TFTP:简单文件传输协议
DHCP:动态主机配置协议
BOOTP:启动协议(用于无盘设备启动)
DNS:域名解析协议