【Linux】传输层协议UDP

在TCP/IP协议中,用"源IP", "源端口号","目的IP","目的端口号","协议号"这样的五元组来标识一个通信

1. 端口号

端口号范围划分

  • 0-1023:知名端口号,HTTP,FTP,SSH等这些广为使用的应用层协议,端口号都是固定的
  • 1024-65535:操作系统动态分配的端口号,客户端程序的端口号,就是由操作系统从这个范围分配的

问题

  • 一个进程可以bind多个端口号
  • 一个端口号只能被一个进程bind

2. UDP协议

2.1 UDP协议端格式

  • 16位UDP长度,表示整个数据报(UDP首部+UDP数据)的最大长度
  • 如果校验和出错,就会直接丢弃

2.2 UDP的特点

UDP 类比普通寄平信

  1. **无连接:**只要知道对方IP + 端口,直接发数据,不用建立连接。

  2. **不可靠:**没有确认应答、没有重传。半路丢包了,UDP 也给应用层返回错误信息

  3. **面向数据报:**一次发一个完整数据包,不会拆包、也不会粘包;读写次数严格对应,不能随意拆分、合并收发的数据

2.3 面向数据报

应用层交给UDP多长的报文,UDP原样发送,不会拆包、也不会粘包

2.4 UDP的缓冲区

  • UDP没有 真正的发送缓冲区,调用sendto把数据直接交给内核,内核立刻转给网络层封装发送
  • UDP 有接收缓冲区 ,能缓存收到的 UDP 数据包;但不保证收发顺序 :先发的包可能后到。缓冲区满了直接丢新包:不会阻塞、不会限流,新来的数据直接丢弃

同一个 UDP Socket 既能收数据、也能发数据,收发相互独立,可以同时进行,这就是全双工

2.5 UDP使用注意事项

UDP 首部有16 位长度字段,说明 UDP 首部 8 字节 + 数据载荷不能超过65536 字节 = 64k

64K 很小,远不够传大文件、大图等

如果需要传输的数据超过64K,就需要在应用层手动的分包,多次发送,并在接收端手动拼装

相关推荐
日取其半万世不竭22 分钟前
iftop、nethogs 和 nload:Linux 服务器网络流量实时监控工具介绍
linux·运维·服务器
mounter62534 分钟前
Linux 内核资源管理:控制组(cgroup)的演进与“策略组”新提案
linux·运维·服务器·cgroup·kernel
bksczm36 分钟前
文件在磁盘中的存储方式
linux·运维·服务器
L16247637 分钟前
OpenSSH 半自动升级方案(独立编译 + 手动迁移 + 重建 systemd 服务)
linux·服务器·ssh
半旧夜夏42 分钟前
【保姆级】微服务组件环境搭建(Docker Compose版)
java·linux·spring cloud·微服务·云原生·容器
Cheng小攸1 小时前
综合实验2
网络·windows
Soari2 小时前
SSH 主机密钥冲突
运维·网络·ssh
爱莉希雅&&&2 小时前
zabbix快速搭建和使用
android·linux·数据库·zabbix·监控
z200509302 小时前
【linux学习】深入理解linux文件I/O,从C标准库到内核态
linux·学习·操作系统
weixin_307779133 小时前
面向高性能保密计算的定制 Linux 系统构建与自动部署方案
linux·安全·网络安全·性能优化·系统安全