UDP协议端格式
- 16位源端端口、16位目的端端口:描述端与端之间的通信
- 16位UDP长度:表示整个数据报(UDP首部+UDP数据)的最大长度,限制了UDP报文总长度(包含报头在内)不能超过64K
- 16位校验和:使用二进制反码求和算法,校验接收的数据与发送的数据是否一致
二进制反码求和算法:对报文从头开始每个字节进行取反相加,高出16位则截断高位,再与低16位继续相加,得到校验和
UDP的特点
- 无连接:不需要建立连接,只要知道对端的地址信息就可以直接发送数据
- 不可靠:UDP在传输层不保证数据可以安全有序的到达对端,需要程序员在应用层进行包序管理
- 面向数据报:不能够灵活的控制读写数据的次数和数量。是一种有最大长度限制的传输方式,取决于数据报长度字段,因为长度字段只有16位,因此数据报总长度不能超过64K,也就是说sendto接口给予的数据长度不能大于64K-8(报头占8个字节)。因此若要传输的数据比较大,则需要程序员在应用层进行分包操作,并且进行包序管理。
UDP的缓冲区
UDP通信在报头中确定了数据报的长度,因此UDP数据的传输是整条收发的
发送:sendto给与的数据放到发送缓冲区后就会直接封装头部,进行发送
接收:recvfrom总是只能接收一条完整的数据,而不会出现接收半条或者多条的情况
因此recvfrom给与的缓冲区一定要足够大,若给与的缓冲区大小小于一条数据的长度,则recvfrom就会报错,因为UDP无法交付半条数据。
- UDP没有真正意义上的发送缓冲区,调用sendto会直接交给内核,由内核将数据传给网络层协议进行后续的传输。
- UDP具有接收缓冲区,但是这个接收缓冲区不能保证接收到的UDP报文的顺序和发送UDP报文的顺序一致,如果缓冲区满了,后续到达的UDP数据就会被丢弃。
全双工:UDP的socket既能读也能写。
基于UDP的应用层协议
NFS:网络文件系统
大多数场景是工作在局域网当中的,在局域网当中NFS客户端和NFS服务端进行通信,通过UDP协议将NFS客户端的指令传递给NFS服务端,NFS服务端将指令传递给某个网络文件系统当中的主机,从而实现远端访问文件系统。
DHCP:动态主机配置协议
由于上网的机器特别多,ipv4版本的ip地址不够用,为了满足日益增长的上网需求。对上网的机器动态分配ip地址,谁连接才给谁分配ip地址,没有连接到网络当中的机器就不获取ip地址。DHCP协议是通过UDP广播来获取ip地址的。