UDP协议详解(UDP协议特点,UDP协议格式、UDP的应用)


前言

TCP和UDP协议都是传输层的协议,其中传输层是负责端对端之间的连接,端是指端点。

端口的划分和知名端口

  • 0~1023:知名端口
  • 3306:Mysql数据库
  • 1521:Oracle数据库
  • 22:ssh服务器
  • 21:ftp服务器
  • 23:telnet服务器
  • 80:http服务器
  • 443:https服务器

可以使用cat /etc/services查看知名端口

① 一个进程是否可以bind多个端口号?

可以的,一个进程可以绑定多个端口号。

② 一个端口号是否可以被多个进程bind?

是不行的,一个端口一次只能被一个进程所绑定。

我们可以使用netstat [选项]命令来查询网络状态。

  • n :拒绝显示别名,能显示数字的全部转化成数字
  • l:仅列出有在 Listen (监听) 的服務状态
  • p:显示建立相关链接的程序名
  • t:(tcp)仅显示tcp相关选项
  • u:(udp)仅显示udp相关选项
  • a:(all)显示所有选项,默认不显示LISTEN相关
    .

举个例子的话就是 可以使用 netstat -anp | grep [端口号]来查看当前某个端口的具体情况。

1.UDP协议的特点

UDP协议的特点就是无连接、不可靠、面向数据报的,整个过程就像是一个寄信的过程,每次接收和发送数据均是整条进行发送。

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

2. UDP协议格式的特点

在这里插入图片描述
我们再来看看,udp的定义:
在这里插入图片描述

① 16位源端口号:数据从哪个端口发送出来的,换一句话说,数据是从哪一个进程中被发送出来的

② 16位目的端口号:数据想要到哪一个端口去,换句话说,数据想要往哪一个端口去。

③ 16位UDP长度:即UDP所能支持的数据长度,即UDP数据最大支持65536的长度。

问题:想要使用UDP协议发送大于65536(216)的数据,应该如何发送?
解答:可以采用自定制协议,(HTTP协议所使用的TCP协议),但是在使用自定制协议的时候,要使用两个标识符,一个标识符用来标识是否为同一条数据,另一个标识符用来标识当前数据的位置,即用来判断数据的前后位置(偏移量)。
解法二:也可以直接使用自定制协议限定大小,然后在同一个逻辑下多次调用sendto接口
注意:由于UDP最大长度为65536,但是其中还包含了头部的8个字节,因此在每次发送数据的时候,最大发送65536 - 8 = 65528个字节。

④ 16位校验和:校验数据在传输过程中是否失真。

  • 首先在发送方进行填充,接收方进行检验。
    对于接收方而言,如果接收成功了,就会将数据递交给应用层。如果校验失败了,即使数据已经传输到了UDP协议中,也会直接被丢弃掉,因为又可能在传输过程中失真了。
  • 对于发送方来说,要对其进行填充,方法是:将除过校验和的16比特位,其余的按照16个比特位进行相加。(在相加的过程中如果出现比特位超过16位的情况,则需要进行回卷)

回卷的策略:最高位 + 低16位 计算出来新的值。

  • 然后再将加完的结果进行反码运算,再将反码运算的结果放到16位校验和中去。
  • 对于接收方而言,对所有的16个比特位进行相加,如果相加的和全为1,则数据是正确的,否则数据就失真。

在这里插入图片描述

这里也能体现出UDP不可靠的特性:若接收方检验到数据失真则就直接丢弃不用,若是数据在转发过程中丢失,也直接丢弃。

⑤ 数据:应用层的数据(有效载荷)

⑥ UDP缓冲区

发送缓冲区:将应用层数据打上UDP报头之后,直接递交给网络层
接收缓冲区:去掉UDP报头,将数据递交给应用层,需要注意的是UDP协议并不保证数据的有序到达。

3. UDP的应用

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

当然, 也包括你自己写UDP程序时自定义的应用层协议.

  • 8
    点赞
  • 37
    收藏
    觉得还不错? 一键收藏
  • 3
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值