《TCP/IP 详解 卷1:协议》第 10 章:用户数据报协议
引言
UDP 稍微扩展了IP协议,使得包可以在进程间传送,而不仅仅是在主机件。——《CSAPP》
IP 数据报是指 IP 层端到端的传输单元。分组(packet)是 IP 层和链路层的传输单元。一个分组可以是一个完整的数据报,也可以是一个分片。——《TCP/IP协议详解卷一 第一版》
UDP 是一种保留消息边界(与TCP的区别中容易忽略的一点)的简单的面相数据报的传输层协议。它不提供差错纠正、队列管理、重复消除、流量控制、拥塞控制。它提供端到端差错检测,也就是传输层端到端校验和,也不保证报文一定能到达目的地。一般来说,每个被应用程序请求的 UDP 输出操作只产生一个 UDP 数据报,从而发送一个 IP 数据报,这一点不同于 TCP 面相数据流的特征。
UDP 本身是提供最小功能的传输层协议:它把应用程序传给 IP 层的数据发送出去。【RFC0768】是 UDP 30 多年来未改变的标准。虽然可靠性和保护性有所缺失,但 UDP 不是一无是处的。因为它的简单,因为它的无连接性,UDP 比其他的传输层协议的开销要小得多。另外,组播和广播操作更多使用 UDP 这样无连接的传输。
UDP header
| 字段 | 长度(bytes) | 含义 |
|---|---|---|
| 源端口号 | 2 | 见下文“端口号” |
| 目的端口号 | 2 | 见下文“端口号” |
| 长度 | 2 | UDP头部和数据的总长度,以字节为单位 |
| 检验和 | 2 | 见下文“UDP检验和” |
端口号
- 端口号相当于电话号码之后的扩展码,帮助协议辨认进程。
- 它们是抽象的,即不与任何主机、任何物理实体相关。
- 在 UDP 中,端口号是 16 位的特殊数字(0~65535)。
- 源端口号是可选择的,如果发送者不要求回复的话,可以设置源端口号为 0.
- IP 层根据协议字段或 IPv6头部中的下一个头部字段分离到特定的传输协议,这意味着端口号在不同的传输层协议之间是独立的。TCP 端口号只能被 TCP 使用,UDP 亦然。(尽管如此,但如果某个众所周知的服务同时由 TCP 和 UDP 提供,那么这两个端口号通常被分配成一样的)
UDP 检验和
- UDP 校验和是我们遇到的第一个传输层端到端检验和(ICMP 是网络层第一个端到端校验和)。UDP 校验和覆盖 UDP 头部、UDP 数据和 UDP 伪头部。端到端是指由发送方计算得到,由最终的接收方检验,途中不会被修改(除非是通过 NAT)。
- 对比只覆盖头部的 IPv4 检验和,经过每一跳路由器都要修改。传输层协议检验和覆盖传输层协议头部和数据。
- “UDP 伪头部”是指UDP数据报长度可以是奇数长字节,而检验和算法只相加 16 位字(偶数字节),因此对于奇数字节长度的数据报,UDP 会在末尾添加一个都为 0 的填充。仅为了计算校验和,不会被传递出去。
UDP 和 IP 分片
在链路层中有介绍,链路层对可传输帧长度有一个最大上限。IP 引入分片和重组。IP 转发时,做出的判断,不仅根据路由表,也根据要求的 MTU 是多少。如果数据报太大则进行分片。
- 分片可以在发送方到目的地上的端到端路径上任何中间路由器进行。
- 重组直到它到达最终目的地才会被重组。原因有二:一、网络中不进行重组减轻路由器的负担。二、不同分片可能经过不同路径到达目的地,这样的话路由器没有能力来重组。
总结
UDP 是一个简单的协议。它给 IP层之上的用户进程提供了端口号和检验和机制。没有流量控制、拥塞控制、差错纠正。有差错检测和消息边界保留。
我们看到了 UDP 用于IP 分片、路径 MTU 发现。当出现如下情况,最常用的就是 UDP 了:
- 要避免建立连接的开销。
- 多端点传送(组播、广播)
- 不需要 TCP 相对笨重的可靠
UDP 的主要用途之一是 DNS(域名系统)。UDP 占据了观察到的互联网流量的 10% - 40%,随着点对点应用数量的增加,UDP 的使用仍在上升,虽然 TCP 在稳定性方面占据了统治地位。网络分片流量大多数 UDP 的,尽管总体流量中只有极少数是分片。分片中的流量类型主要有基于 UDP 的多媒体流量、VPN 隧道中封装的隧道流量。
《TCP/IP 详解 卷1:协议》第 10 章:用户数据报协议的更多相关文章
- TCP/IP详解 卷1 第十九章 TCP的交互数据流
19.1 引言 成块数据:比如ftp.电子邮件.Usenet新闻 交互数据:Telnet.Rlogin 成块数据的报文段基本上都是满长度(full-size)的,而交互数据小的多(Telnet和Rlo ...
- 《TCP/IP详解卷1:协议》第1章 概述-读书笔记
章节回顾: <TCP/IP详解卷1:协议>第1章 概述-读书笔记 <TCP/IP详解卷1:协议>第2章 链路层-读书笔记 <TCP/IP详解卷1:协议>第3章 IP ...
- 《TCP/IP详解卷1:协议》第2章 链路层-读书笔记
章节回顾: <TCP/IP详解卷1:协议>第1章 概述-读书笔记 <TCP/IP详解卷1:协议>第2章 链路层-读书笔记 <TCP/IP详解卷1:协议>第3章 IP ...
- 《TCP/IP详解卷1:协议》第3章 IP:网际协议(1)-读书笔记
章节回顾: <TCP/IP详解卷1:协议>第1章 概述-读书笔记 <TCP/IP详解卷1:协议>第2章 链路层-读书笔记 <TCP/IP详解卷1:协议>第3章 IP ...
- 《TCP/IP详解卷1:协议》第3章 IP:网际协议(2)-读书笔记
章节回顾: <TCP/IP详解卷1:协议>第1章 概述-读书笔记 <TCP/IP详解卷1:协议>第2章 链路层-读书笔记 <TCP/IP详解卷1:协议>第3章 IP ...
- 《TCP/IP详解卷1:协议》第4章 ARP:地址解析协议-读书笔记
章节回顾: <TCP/IP详解卷1:协议>第1章 概述-读书笔记 <TCP/IP详解卷1:协议>第2章 链路层-读书笔记 <TCP/IP详解卷1:协议>第3章 IP ...
- 《TCP/IP详解卷1:协议》第5章 RARP:逆地址解析协议-读书笔记
章节回顾: <TCP/IP详解卷1:协议>第1章 概述-读书笔记 <TCP/IP详解卷1:协议>第2章 链路层-读书笔记 <TCP/IP详解卷1:协议>第3章 IP ...
- 《TCP/IP详解卷1:协议》第6章 ICMP:Internet控制报文协议-读书笔记
章节回顾: <TCP/IP详解卷1:协议>第1章 概述-读书笔记 <TCP/IP详解卷1:协议>第2章 链路层-读书笔记 <TCP/IP详解卷1:协议>第3章 IP ...
- 《TCP/IP详解卷1:协议》第11章 UDP:用户数据报协议-读书笔记
章节回顾: <TCP/IP详解卷1:协议>第1章 概述-读书笔记 <TCP/IP详解卷1:协议>第2章 链路层-读书笔记 <TCP/IP详解卷1:协议>第3章 IP ...
- 《TCP/IP详解卷1:协议》第17、18章 TCP:传输控制协议(1)-读书笔记
章节回顾: <TCP/IP详解卷1:协议>第1章 概述-读书笔记 <TCP/IP详解卷1:协议>第2章 链路层-读书笔记 <TCP/IP详解卷1:协议>第3章 IP ...
随机推荐
- Web安全0001 - MySQL SQL注入 - 如何寻找注入点
注:本文是学习网易Web安全进阶课的笔记,特此声明. 其他数据库也可以参考寻找注入点. A: 一.信息搜集(百度) 1.无特定目标 inurl:.php?id= 2.有特定目标 inurl:.php? ...
- mysql远程连接权限设置
今儿有位同事提出,一套MySQL 5.6的环境,从数据库服务器本地登录,一切正常,可是若从远程服务器访问,就会报错, ERROR 1045 (28000): Access denied for use ...
- Nginx基于TCP的负载均衡的配置例子
原文:https://blog.csdn.net/bigtree_3721/article/details/72833955 nginx-1.9.0 已发布,该版本增加了 stream 模块用于一般的 ...
- python基础学习1-函数相关
#!/usr/bin/env python # -*- coding:utf-8 -*- 函数相关 def f1(par,par2,par3="ok"): #定义函数 带参数,带参 ...
- 【LG3722】[HNOI2017]影魔
[LG3722][HNOI2017]影魔 题面 洛谷 题解 先使用单调栈求出\(i\)左边第一个比\(i\)大的位置\(lp_i\),和右边第一个比\(i\)大的位置\(rp_i\). 考虑\(i\) ...
- 4538: [Hnoi2016]网络
4538: [Hnoi2016]网络 链接 分析: 整体二分. 对于一次操作,可以二分一个答案mid,判断权值大于mid的路径是否全部经过这个点.如果是 ,那么这次询问的答案在[l,mid-1]之间, ...
- P3704 [SDOI2017]数字表格
P3704 [SDOI2017]数字表格 链接 分析: $\ \ \ \prod\limits_{i = 1}^{n} \prod\limits_{j = 1}^{m} f[gcd(i, j)]$ $ ...
- Kubernetes学习之路(九)之kubernetes命令式快速创建应用
1.使用命令kubectl run创建应用 语法: kubectl run NAME --image=image [--env="key=value"] [--port=port] ...
- Masonry的简单使用(一)
Masonry的简单使用(一) 一.新建工程 二.导入Masonry,可从我的GitHub上获取"Masonry":https://github.com/sycFuture/Mas ...
- jquery.validata1.11怎么支持metadata
使用metadata方式这个需要使用jquery.metadata.js插件才可工作,通过在表单项中定义特殊的属性来指定验证规则 但是最新的jquery.validate 1.11没有内置metada ...