当前位置: 首页 > ds >正文

网络原理——UDP

1、 与TCP的关键区别

特性UDPTCP
连接方式无连接面向连接
可靠性不可靠可靠
数据顺序不保证顺序保证顺序
传输速度更快相对较慢
头部开销8字节20-60字节
流量控制
拥塞控制
适用场景实时应用、广播/多播可靠性要求高的应用

2、UDP 报文结构

报文结构大致可以分为首部和载荷(需要传输的数据部分),首部又有源端口、目的端口、长度、校验和几个部分,起大小都是 2 字节。

端口号:是一个无符号的整数,范围在 0~65535

UDP长度:这里的长度是表示的整个 UDP 的长度,所以一条 UDP 数据报的最大为 64 KB

校验和:验证 UDP 数据报在传输过程过程当中是否发生出错

3、理解 UDP 的 "不可靠"

应⽤层交给 UDP 多⻓的报⽂ , UDP 原样发送, 既不会拆分, 也不会合并; 

⽤ UDP 传输100个字节的数据:  • 如果发送端调⽤⼀次sendto, 发送100个字节, 那么接收端也必须调⽤对应的⼀次recvfrom, 接收100 个字节; ⽽不能循环调⽤10次recvfrom, 每次接收10个字节; 

也就意味着 UDP 只管发送,不会管接没接受到。

4、UDP使⽤注意事项

我们注意到, UDP 协议⾸部中有⼀个16位的最⼤⻓度. 也就是说⼀个 UDP 能传输的数据最大长度是 64K(包含 UDP ⾸部). 然⽽64K在当今的互联⽹环境下, 是⼀个⾮常⼩的数字.  如果我们需要传输的数据超过64K, 就需要在应⽤层⼿动的分包, 多次发送, 并在接收端⼿动拼装; 

5、为什么不扩容 UDP 长度

很多人有疑惑,既然两字节不够,把它改成 4 字节不就能解决,为什么不扩容呢?

其主要原因就是在设计之初的定位为 “轻量级最小可行协议” ,国际互联网工程任务组(IETF)刻意保持其精简性,将复杂功能交由应用层实现。

而且互联网已经发展那么多年了,全球大大小小的设备都在遵守最初的协议,若现在扩容 ,将会使得,原来的设备无法解析数据报,产生错误。

所以我们可以的使用 TCP 来替代~~

http://www.xdnf.cn/news/931.html

相关文章:

  • element-plus中,Steps 步骤条组件的使用
  • 从多个Excel批量筛查数据后合并到一起
  • CompletableFuture并行处理任务
  • 技术视界 | 开源新视野: 人形机器人技术崛起,开源社区驱动创新
  • Feign
  • IQ信号和实信号的关系与转换的matlab实现
  • kafka监控kafka manager(CMAK)部署配置
  • LX5-STM32F103C8T6引脚分布与定义
  • 在已有 Kubernetes 集群中最小化离线安装 KubeSphere4.1.3
  • 衡石 ChatBI 用户手册-使用指南
  • Docker安装beef-xss
  • 爱家桌面app官方正版下载 爱家最新版免费安装 固件升级方法
  • [特殊字符] Prompt如何驱动大模型对本地文件实现自主变更:Cline技术深度解析
  • stm32week12
  • 《小型支付商城系统》学习记录
  • 测试模版1
  • 4.21总结
  • 思科路由器做DNS服务器
  • [数据可视化] Datagear使用心得:从数据整备到可视化联动实践
  • 基于Hadoop的音乐推荐系统(源码+lw+部署文档+讲解),源码可白嫖!
  • 第二章 Logback的架构(一)
  • 电控---SWD协议
  • Spring Boot 断点续传实战:大文件上传不再怕网络中断
  • 240421 leetcode exercises
  • 堡垒机和跳板机之区别(The Difference between Fortress and Springboard Aircraft)
  • Docker 中将文件映射到 Linux 宿主机
  • C++算法(11):vector作为函数参数的三种传递方式详解
  • Vibracostic EDI 需求分析
  • 安卓的Launcher 在哪个环节进行启动
  • Cursor 配置中文界面并设置浅色背景的方法