网络——从传输层解析udp通信协议

作者:小 琛
欢迎转载,请标明出处

传输层udp协议特点

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

udp协议的格式

在这里插入图片描述

  1. udp协议的报头
    源端口(2字节)+目的端口(2字节)+数据长度(最大可以2^16)+校验和
  2. 数据长度
    uint16_t 最大65536。
    因此当传输层数据大于该值,应用层需要对该数据进行分片传输,即将大于65536的数据进行拆分,通过多次传输实验。

校验和的原理

  1. 作用:校验udp数据在传输的过程中是否有损坏
    若有损坏,不会提交给应用层,直接丢弃。不可靠的体现!
    若无损坏,在应用层recvfrom时提交给应用层
  2. 校验和的工作原理
  1. 将udp数据(报头+数据)分位多个16比特位数据,将除了16个校验和的比特位不进行相加外,针对其它的进行相加操作。
    例如:
    0110 0110 0110 0000 源端口
    0101 0101 0101 0101 目的端口
    0100 0100 0000 0000 数据
    相加结果:1111 1111 1011 0101
  2. 对结果进行反码运算
    0000 0000 0100 1010
  3. 将该反码运算结果存放至16位校验和比特位中
  4. 当接收到udp数据报之后,将所有的16位比特位相加,结果若为1111 1111 1111 1111,则认为数据无损坏,反之位有损坏。

udp的缓冲区

  1. 对于应用层的数据时整条数据接收和发送的;
  2. 对于发送而言,应用层使用sendto接口将数据交给传输层当中的udp的发送缓冲区,在发送缓冲区中,打上udp报头,进行下一步传输
  3. 对于接收,应用层使用recvfrom接口将数据从接收缓冲区中拷贝到应用层,udp接收缓冲区是不保证数据有序到达、也不保证可靠;当接收缓冲区满的时候,从网卡中接收的udp数据包就会被直接丢弃

udp的应用

DHCP:动态分配IP
DNS:域名解析协议
NFS: 网络文件系统
TFTP: 简单文件传输协议
BOOTP: 启动协议(用于无盘设备启动)

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值