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

【网络协议】UDP

UDP协议与TCP协议都是传输层协议,应用层把数据拷贝到传输层,后续动作由下层自行决定。

UDP协议端格式

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

UDP的特点(相对于TCP)

无连接 : 知道对端的 IP 和端口号就直接进行传输 , 不需要建立连接 ;
不可靠 : 没有确认机制 , 没有重传机制 ; 如果因为网络故障该段无法发到对方 , UDP 协议层也不会给应用层返回任何错误信息;
面向数据报 : 不能够灵活的控制读写数据的次数和数量 ;

面向数据报

应用层交给 UDP 多长的报文 , UDP 原样发送 , 既不会拆分 , 也不会合并 ;
UDP 传输 100 个字节的数据 :
如果发送端调用一次 sendto, 发送 100 个字节 , 那么接收端也必须调用对应的一次 recvfrom, 接收 100 个字节; 而不能循环调用 10 recvfrom, 每次接收 10 个字节 ;

UDP的缓冲区

UDP 没有真正意义上的 发送缓冲区 . 调用 sendto 会直接交给内核 , 由内核将数据传给网络层协议进行后续的传输动作;
UDP 具有接收缓冲区 . 但是这个接收缓冲区不能保证收到的 UDP 报的顺序和发送 UDP 报的顺序一致 ; 如果缓冲区满了, 再到达的 UDP 数据就会被丢弃 ;
UDP socket 既能读 , 也能写 , 这个概念叫做 全双工。

UDP使用注意事项

我们注意到 , UDP 协议首部中有一个 16 位的最大长度 . 也就是说一个 UDP 能传输的数据最大长度是 64K( 包含 UDP 首部).
然而 64K 在当今的互联网环境下 , 是一个非常小的数字 .
如果我们需要传输的数据超过 64K, 就需要在应用层手动的分包 , 多次发送 , 并在接收端手动拼装 ;

基于UDP的应用层协议

NFS: 网络文件系统
TFTP: 简单文件传输协议
DHCP: 动态主机配置协议
BOOTP: 启动协议 ( 用于无盘设备启动 )
DNS: 域名解析协议(也可以使用TCP)
当然 , 也包括你自己写 UDP 程序时自定义的应用层协议 ;
问题1:报头和有效载荷如何分离,如何交付?
报头有16位报文长度,减去8字节固定报头长度就是有效载荷。
http://www.lryc.cn/news/182448.html

相关文章:

  • 雷达编程实战之提高探测速度
  • pyspark常用功能记录
  • Spring面试题学习: 单例Bean是单例模式吗?
  • EM@常用三角函数图象性质(中学部分)
  • 一文拿捏Spring事务之、ACID、隔离级别、失效场景
  • input输入表头保存excel文件
  • DataBinding双向绑定简介
  • Is This The Intelligent Model(这是智能模型吗)
  • MySQL事务:特性、使用、并发事务问题和隔离级别
  • FFmpeg日志系统、文件与目录、操作目录
  • 好奇喵 | Surface Web ---> Deep Web ---> Dark Web
  • 三、thymeleaf基本语法
  • 创建一个新的IDEA插件项目
  • Doris数据库BE——冷热数据方案
  • Python无废话-办公自动化Excel格式美化
  • 竞赛 机器视觉的试卷批改系统 - opencv python 视觉识别
  • Django 数据库迁移(Django-04)
  • Redis相关概念
  • Scala第十八章节
  • JAVA学习(4)-全网最详细~
  • 【单片机】12-串口通信和RS485
  • 一步步教你使用GDB调试程序:从入门到精通的全面指南
  • OpenCV读取图像时按照BGR的顺序HWC排列,PyTorch按照RGB的顺序CHW排列
  • 基于安卓android微信小程序的校园维修平台
  • mysql面试题16:说说分库与分表的设计?常用的分库分表中间件有哪些?分库分表可能遇到的问题有哪些?
  • AlexNet网络复现
  • pytorch模型量化和移植安卓详细教程
  • C++(List)
  • 分布式架构篇
  • ros编译报错-- Could NOT find ros_ethercat_eml (missing: ros_ethercat_eml_DIR)