5计算机网络课件-CH5_运输层

合集下载

计算机网络原理5运输层

计算机网络原理5运输层

运输层为相互通信的应用进程提供了 逻辑通信
5 4 3 2 1 IP 层 AP1 AP 2 应用进程 应用进程 端口 运输层提供应用进程间的逻辑通信 端口 AP3 AP4 5 4
3
2 1
主机
主机 B 路由器 1 LAN1 WAN IP 协议的作用范围 运输层协议 TCP 和 UDP 的作用范围 路由器 2 LAN2
计算机网络原理
第 5 章 运输层
课件制作人:谢希仁
第 5 章 运输层
5.1 *运输层协议概述 5.1.1 进程之间的通信 5.1.2 运输层的两个主要协议 5.1.3 运输层的端口 5.2 用户数据报协议 UDP 5.2.1 *UDP 概述 5.2.2 UDP 的首部格式
课件制作人:谢希仁
第 5 章 运输层(续)
课件制作人:谢希仁
面向报文的 UDP




发送方 UDP 对应用程序交下来的报文,在添 加首部后就向下交付 IP 层。UDP 对应用层交 下来的报文,既不合并,也不拆分,而是保留 这些报文的边界。 应用层交给 UDP 多长的报文,UDP 就照样发 送,即一次发送一个报文。 接收方 UDP 对 IP 层交上来的 UDP 用户数据 报,在去除首部后就原封不动地交付上层的应 用进程,一次交付一个完整的报文。 应用程序必须选择合适大小的报文。
课件制作人:谢希仁
5.3.2 TCP 的连接




TCP 把连接作为最基本的抽象。 每一条 TCP 连接有两个端点。 TCP 连接的端点不是主机,不是主机的 IP 地址,不是应用进程,也不是运输层 的协议端口。TCP 连接的端点叫做套接 字(socket)或插口。 端口号拼接到(contatenated with) IP 地 址即构成了套接字。

CH5-5ed 运输层.ppt

CH5-5ed 运输层.ppt
为了使运行不同OS计算机的AP能互相通信,必须 用统一的方法对其进行标志。
考虑:能否用特同定样进不程可的取,名同称一?进程可能实现不同功能,
而不同进程可能合作实现同一功能;且进 程具备动态性。归根结底:在本层中,以 功能来区分作为通信端点进程!
解决办法:端口
什么是端口(port)? 非硬件接口 指运输层与应用层交互的抽象软件端口 SAP
端口的作用: 对不同AP在运输层上加以功能性的标志和区分。 虽然通信的真正终点是AP,但在运输层上,只需 将不同AP的数据提交到端口即可。
AP与端口绑定
AP通过系统调用与某端口绑定。 AP发给运输层的数据都通过该端口发送。 运输层传给AP的数据都从该端口接收。
端口的定义
端口用一个 16 位端口号进行标志。 端口号通常只具有本地意义,即端口号只是为了
5.2 用户数据报协议 UDP 5.2.1 UDP 概述
UDP只在IP数据报服务之上增加了很少一点 的功能,即端口的功能和差错检测的功能。
虽然 UDP 用户数据报只能提供不可靠的交 付,但 UDP 在某些方面有其特殊的优点。
实时通信。 RIP。
UDP 的主要特点
无连接。 尽最大努力交付。 面向报文。 无拥塞控制,很适合实时多媒体通信的要求。 支持一对一、一对多、多对一和多对多的交互
5.1.2 运输层的两个主要协议
TCP/IP 的运输层有两个不同的协议: (1) 用户数据报协议 UDP(UDP报文或数据报) (2) 传输控制协议 TCP (TCP报文段)
TCP 与 UDP
UDP 提供无连接服务,不提供可靠交付。 TCP 提供面向连接的服务。TCP 不提供广播
或多播服务。由于 TCP 要提供可靠的、面向 连接的运输服务,因此不可避免地增加了许多 的开销。这不仅使协议数据单元的首部增大很 多,还要占用许多的处理机资源。 选择TCP 还是 UDP ?

CH05运输层_13

CH05运输层_13
这样得出的加权平均往返时间 RTTS 和超时重传 时间 RTO 就较准确。
但是,这又引起新的问题。当报文段的时延突 然增大了很多时,在原来得出的重传时间内, 不会收到确认报文段。于是就重传报文段。但 根据 Karn 算法,不考虑重传的报文段的往返时 间样本。这样,超时重传时间就无法更新。
P1
P2
P3
B 的接收窗口
26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56
已发送确认 并交付主机
允许接收
不允许接收 接收窗口内的序号(31 ~ 50)
未按序收到
是允许接收的序号。
算加权平均的 RTTD:
新的 RTTD = (1 ) (旧的RTTD) + RTTS 新的 RTT 其推荐值是 1/4,即 0.25。
往返时间 (RTT) 的测量相当复杂
TCP 报文段 1 没有收到确认。重传(即报文段 2)后, 收到了确认报文段 ACK。
已发送并收到确认
已发送
P1 但未收到确认
允许发送但尚未发送 P2
不允许 发送
P3
B 的接收窗口向前滑动
26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56
已发送确认 并交付主机
接收方发送确认
接收方可以在合适的时候发送确认,也可以在 自己有数据要发送时把确认信息顺便捎带上。
但请注意两点:
第一,接收方不应过分推迟发送确认,否则会导致 发送方不必要的重传,这反而浪费了网络的资源。

CH05-运输层

CH05-运输层
计算机网络简明教程
第 5 章 运输层
第 5 章 运输层
5.1 运输层协议概述 5.1.1 进程之间的通信 5.1.2 运输层的两个主要协议 5.1.3 运输层的端口 5.2 用户数据报协议 UDP 5.3 传输控制协议 TCP 概述 5.3.1 TCP 最主要的特点 5.3.2 TCP 的连接
第 5 章 运输层(续)
5.1.2 运输层的两个主要协议
TCP/IP 的运输层有两个不同的协议: (1) 用户数据报协议 UDP (User Datagram Protocol) (2) 传输控制协议 TCP (Transmission Control Protocol)
TCP/IP 体系中的运输层协议
应用层
运输层
UDP
网络环境中分布式进程通信需要解决的3个问题:

进程命名与寻址方法

多重协议的识别
进程间相互作用的模式

网络环境中进程标识
在一台计算机中,不同的进程用进程号或进程 标识(process ID)惟一地标识出来。 网络环境中完整的进程标识应该是: • 本地主机地址-本地进程标识 ; • 远程主机地址-远程进程标识。
AP1 AP2
AP3
AP4
应用进程之间的通信


两个主机进行通信实际上就是两个主机中的应 用进程互相通信。 应用进程之间的通信又称为端到端的通信。 运输层的一个很重要的功能就是复用和分用。 应用层不同进程的报文通过不同的端口向下交 到运输层,再往下就共用网络层提供的服务。 “运输层提供应用进程间的逻辑通信”。“逻 辑通信”的意思是:运输层之间的通信好像是 沿水平方向传送数据。但事实上这两个运输层 之间并没有一条水平方向的物理连接。

计算机网络_第五章_运输层

计算机网络_第五章_运输层

运输层为相互通信的应用进程提供了 逻辑通信
5 4 3 2 1 IP 层 AP1 AP 2 应用进程 应用进程 端口 运输层提供应用进程间的逻辑通信 端口 AP3 AP4 5 4
3
2 1
主机 A
主机 B 路由器 1 LAN1 WAN IP 协议的作用范围 运输层协议 TCP 和 UDP 的作用范围 路由器 2 LAN2
5.1.2 运输层的两个主要协议
TCP/IP 的运输层有两个不同的协议: (1) 用户数据报协议 UDP (User Datagram Protocol) (2) 传输控制协议 TCP (Transmission Control Protocol)
TCP 与 UDP

两个对等运输实体在通信时传送的数据单位叫作 运输协议数据单元 TPDU (Transport Protocol Data Unit)。
三类端口


熟知端口,数值一般为 0~1023。 登记端口号,数值为1024~49151,为没有熟 知端口号的应用程序使用的。使用这个范围的 端口号必须在 IANA 登记,以防止重复。 客户端口号或短暂端口号,数值为 49152~65535,留给客户进程选择暂时使用。 当服务器进程收到客户进程的报文时,就知道 了客户进程所使用的动态端口号。通信结束后, 这个端口号可供其他客户进程以后使用。
AP1 AP2
AP3
AP4
应用进程之间的通信


两个主机进行通信实际上就是两个主机中的应 用进程互相通信。 应用进程之间的通信又称为端到端的通信。 运输层的一个很重要的功能就是复用和分用。 应用层不同进程的报文通过不同的端口向下交 到运输层,再往下就共用网络层提供的服务。 “运输层提供应用进程间的逻辑通信”。“逻 辑通信”的意思是:运输层之间的通信好像是 沿水平方向传送数据。但事实上这两个运输层 之间并没有一条水平方向的物理连接。

CH5-运输层解析

CH5-运输层解析

面向信息处理
应用层
用户功能
运输层
面向通信
网络层 数据链路层
网络功能
物理层
•当网络的边缘部分中的两个主机使用网络的核心部分的
功能进行端到端的通信时,只有位于网络边缘部分的主机
的协议栈才有运输层,而网络核心部分中的路由器在转发
分组时都只用到下三层的功能。
应用进程之间的通信
• 两个主机进行通信实际上就是两个主机中的应用 进程互相通信。
与各种网络接口
TCP/IP 体系中的运输层协议
TCP 与 UDP
• UDP 在传送数据之前不需要先建立连接。对方 的运输层在收到 UDP 报文后,不需要给出任何 确认。虽然 UDP 不提供可靠交付,但在实时情 况下 UDP 是一种最有效的工作方式。
• TCP 则提供面向连接的服务。TCP 不提供广播 或多播服务。由于 TCP 要提供可靠的、面向连 接的运输服务,因此不可避免地增加了许多的开 销。这不仅使协议数据单元的首部增大很多,还 要占用许多的处理机资源。
• 应用进程之间的通信又称为端到端的通信。
• 运输层的一个很重要的功能就是复用和分用。应 用层不同进程的报文通过不同的端口向下交到运 输层,再往下就共用网络层提供的服务。
• “运输层提供应用进程间的逻辑通信”。“逻辑 通信”的意思是:运输层之间的通信好像是沿水 平方向传送数据。但事实上这两个运输层之间并 没有一条水平方向的物理连接。
运输层协议和网络层协议的主要区别
应用进程

因特网
应用进程

IP 协议的作用范围 (提供主机之间的逻辑通信)
TCP 和 UDP 协议的作用范围 (提供进程之间的逻辑通信)
运输层的主要功能
• 运输层为应用进程之间提供端到端的逻辑通信 (但网络层是为主机之间提供逻辑通信)。

第五章 运输层

第五章 运输层

4 目的 IP 地址
11 2 0 17 UDP长度
字节
12
2
2
2
伪首部 源端口 目的端口 长 度
2 检验和
UDP 用户数据报
发送在前 首部
首部
数据
数据 IP 数据报
UDP
UDP (User Datagram Protocol)的特点是:
不可靠 (Unreliable) 无连接 (Connectionless) 不保证按顺序接收 不提供流量控制 不提供拥塞控制
源端口
目的端口
序号
确认号
保留
U AP RSF R CS SY I G KH T NN
检验和
窗口 紧急指针
选 项 (长 度 可 变)
填充
20 字节
固定
首部
紧急比特 URG —— 当 URG 1 时,表明紧急指 针字段有效。它告诉系统此报文段中有紧急数据, 应尽快传送(相当于高优先级的数据)。
比特 0

出队列
入队列
UDP 端口 69
UDP 用户数据报
5.3.2 UDP 用户数据报的 首部格式
字节
4 源 IP 地址
4 目的 IP 地址
11 2 0 17 UDP长度
字节
12
2
2
2
伪首部 源端口 目的端口 长 度
2 检验和
UDP 用户数据报 首 部
发送在前 首部
数据
数据 IP 数据报
用户数据报 UDP 有两个字段:数据字段和首部 字段。首部字段有 8 个字节,由 4 个字段组成, 每个字段都是两个字节。
TCP (Transmission Control Protocol)

北京邮电大学计算机网络课件第五章:运输层

北京邮电大学计算机网络课件第五章:运输层
运输层上司的判断和决策在很大程度上是根据秘书的汇报作出来的汇报的内容是否真实汇报的数据是否准确汇报的用语是否恰当运输层51运输层协议概述511进程之间的通信512运输层的两个主要协议513运输层的端口52用户数据报协议udp521udp概述522udp的首部格式上司的判断和决策在很大程度上是根据秘书的汇报作出来的汇报的内容是否真实汇报的数据是否准确汇报的用语是否恰当运输层续53传输控制协议tcp概述531tcp最主要的特点532tcp的连接54可靠传输的工作原理541停止等待协议542连续arq协议55tcp报文段的首部格式上司的判断和决策在很大程度上是根据秘书的汇报作出来的汇报的内容是否真实汇报的数据是否准确汇报的用语是否恰当运输层续56tcp可靠传输的实现561以字节为单位的滑动窗口562超时重传时间的选择563选择确认sack57tcp的流量控制571利用滑动窗口实现流量控制571必须考虑传输效率上司的判断和决策在很大程度上是根据秘书的汇报作出来的汇报的内容是否真实汇报的数据是否准确汇报的用语是否恰当运输层续58tcp的拥塞控制581拥塞控制的一般原理582几种拥塞控制方法583随机早期检测red59tcp的运输连接管理591tcp的连接建立592tcp的连接释放593tcp的有限状态机上司的判断和决策在很大程度上是根据秘书的汇报作出来的汇报的内容是否真实汇报的数据是否准确汇报的用语是否恰当51运输层协议概述511进程之间的通信从通信和信息处理的角度看运输层向它上面的应用层提供通信服务它属于面向通信部分的最高层同时也是用户功能中的最低层
三类端口


熟知端口,数值一般为 0~1023。 登记端口号,数值为1024~49151,为没有熟 知端口号的应用程序使用的。使用这个范围的 端口号必须在 IANA 登记,以防止重复。 客户端口号或短暂端口号,数值为 49152~65535,留给客户进程选择暂时使用。 当服务器进程收到客户进程的报文时,就知道 了客户进程所使用的动态端口号。通信结束后, 这个端口号可供其他客户进程以后使用。
  1. 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
  2. 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
  3. 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。

需要解决的问题



由于进程的创建和撤销都是动态的,发 送方几乎无法识别其他机器上的进程。 有时我们会改换接收报文的进程,但并 不需要通知所有发送方。 我们往往需要利用目的主机提供的功能 来识别终点,而不需要知道实现这个功 能的进程。
端口号(protocol port number) 简称为端口(port)

5.1.3 运输层的端口


运行在计算机中的进程是用进程标识符来标志的。 运行在应用层的各种应用进程却不应当让计算机操 作系统指派它的进程标识符。这是因为在因特网上 使用的计算机的操作系统种类很多,而不同的操作 系统又使用不同格式的进程标识符。 为了使运行不同操作系统的计算机的应用进程能够 互相通信,就必须用统一的方法对 TCP/IP 体系的 应用进程进行标志。
TCP 面向流的概念
发送方

接收方
H 表示 TCP 报文段的首部 x 表示序号为 x 的数据字节 从接收缓存 读取字节 加上 TCP 首部 构成 TCP 报文段 TCP 5 4
应用进程

应用进程
21 字节流 20 把字节写入 19 发送缓存
TCP 1817161514
0 字节流 1 2 3
131211 H
10 9 H TCP 连接
发送 TCP 报文段 8 7 6H
UDP 用户数据报 发送在前 首 部
首 部


数 IP 数据报

UDP 基于端口的分用
端口 1 端口 2 端口 3
UDP 分用 UDP 数据报到达
IP 层
用户数据报 UDP 有两个字段:数据字段和首部 字段。首部字段有 8 个字节,由 4 个字段组成, 每个字段都是两个字节。
字节 4 源 IP 地址 字节 12 伪首部 4 目的 IP 地址 2 源端口 2 目的端口 1 0 1 2 17 UDP长度 2 检验和
5.1.2 运输层的两个主要协议
TCP/IP 的运输层有两个不同的协议: (1) 用户数据报协议 UDP (User Datagram Protocol) (2) 传输控制协议 TCP (Transmission Control Protocol)
TCP 与 UDP

两个对等运输实体在通信时传送的数据单位叫作 运输协议数据单元 TPDU (Transport Protocol Data Unit)。
两种不同的运输协议



运输层向高层用户屏蔽了下面网络核心的细节 (如网络拓扑、所采用的路由选择协议等), 它使应用进程看见的就是好像在两个运输层实 体之间有一条端到端的逻辑通信信道。 当运输层采用面向连接的 TCP 协议时,尽管 下面的网络是不可靠的(只提供尽最大努力服 务),但这种逻辑通信信道就相当于一条全双 工的可靠信道。 当运输层采用无连接的 UDP 协议时,这种逻 辑通信信道是一条不可靠信道。
软件端口与硬件端口


在协议栈层间的抽象的协议端口是软件 端口。 路由器或交换机上的端口是硬件端口。 硬件端口是不同硬件设备进行交互的接 口,而软件端口是应用层的各种协议进 程与运输实体进行层间交互的一种地址。
TCP 的端口

端口用一个 16 位端口号进行标志。 端口号只具有本地意义,即端口号只是为 了标志本计算机应用层中的各进程。在因 特网中不同计算机的相同端口号是没有联 系的。

还要强调两点

运输层的 UDP用户数据报与网际层的IP数据报 有很大区别。IP 数据报要经过互连网中许多路 由器的存储转发,但 UDP 用户数据报是在运输 层的端到端抽象的逻辑信道中传送的。 TCP 报文段是在运输层抽象的端到端逻辑信道 中传送,这种信道是可靠的全双工信道。但这 样的信道却不知道究竟经过了哪些路由器,而 这些路由器也根本不知道上面的运输层是否建 立了 TCP 连接。
5.2 用户数据报协议 UDP
5.2.1 UDP 概述


UDP 只在 IP 的数据报服务之上增加 了很少一点的功能,即端口的功能和 差错检测的功能。 虽然 UDP 用户数据报只能提供不可靠 的交付,但 UDP 在某些方面有其特殊 的优点。
UDP 的主要特点




UDP 是无连接的,即发送数据之前不 需要建立连接。 UDP 使用尽最大努力交付,即不保证 可靠交付,同时也不使用拥塞控制。 UDP 是面向报文的。UDP 没有拥塞控 制,很适合多媒体通信的要求。 UDP 支持一对一、一对多、多对一和 多对多的交互通信。 UDP 的首部开销小,只有 8 个字节。
三类端口


熟知端口,数值一般为 0~1023。 登记端口号,数值为1024~49151,为没有熟 知端口号的应用程序使用的。使用这个范围的 端口号必须在 IANA 登记,以防止重复。 客户端口号或短暂端口号,数值为 49152~65535,留给客户进程选择暂时使用。 当服务器进程收到客户进程的报文时,就知道 了客户进程所使用的动态端口号。通信结束后, 这个端口号可供其他客户进程以后使用。
第 5 章 运输层(续)
5.6 TCP 可靠传输的实现 5.6.1 以字节为单位的滑动窗口 5.6.2 超时重传时间的选择 5.6.3 选择确认 SACK 5.7 TCP的流量控制 5.7.1 利用滑动窗口实现流量控制 5.7.1 必须考虑传输效率
第 5 章 运输层(续)
5.8 TCP 的拥塞控制 5.8.1 拥塞控制的一般原理 5.8.2 几种拥塞控制方法 5.8.3 随机早期检测 RED 5.9 TCP 的运输连接管理 5.9.1 TCP 的连接建立 5.9.2 TCP 的连接释放 5.9.3 TCP 的有限状态机
计算机网络(第 5 版)
第 5 章 运输层
第 5 章 运输层
5.1 运输层协议概述 5.1.1 进程之间的通信 5.1.2 运输层的两个主要协议 5.1.3 运输层的端口 5.2 用户数据报协议 UDP 5.2.1 UDP 概述 5.2.2 UDP 的首部格式
第 5 章 运输层(续)
5.3 传输控制协议 TCP 概述 5.3.1 TCP 最主要的特点 5.3.2 TCP 的连接 5.4 可靠传输的工作原理 5.4.1 停止等待协议 5.4.2 连续 ARQ 协议 5.5 TCP 报文段的首部格式
8 字节 UDP 首部
7 字节 数据
按二进制反码运算求和 10010110 11101101 → 求和得出的结果 将得出的结果求反码 01101001 00010010 → 检验和
5.3 传输控制协议 TCP 概述
5.3.1 TCP 最主要的特点



TCP 是面向连接的运输层协议。 每一条 TCP 连接只能有两个端点 (endpoint),每一条 TCP 连接只能是点 对点的(一对一)。 TCP 提供可靠交付的服务。 TCP 提供全双工通信。 面向字节流。
TCP 传送的数据单位协议是 TCP 报文段 (segment)


UDP 传送的数据单位协议是 UDP 报文或用户数 据报。
TCP/IP 体系中的运输层协议
应用层
运输层
UDP
IP
TCP
与各种网络接口
TCP 与 UDP

UDP 在传送数据之前不需要先建立连接。对 方的运输层在收到 UDP 报文后,不需要给出 任何确认。虽然 UDP 不提供可靠交付,但在 某些情况下 UDP 是一种最有效的工作方式。 TCP 则提供面向连接的服务。TCP 不提供广 播或多播服务。由于 TCP 要提供可靠的、面 向连接的运输服务,因此不可避免地增加了许 多的开销。这不仅使协议数据单元的首部增大 很多,还要占用许多的处理机资源。
运输层协议和网络层协议 的主要区别
应用进程 应用进程




因 特 网
IP 协议的作用范围 (提供主机之间的逻辑通信)
TCP 和 UDP 协议的作用范围 (提供进程之间的逻辑通信)
运输层的主要功能


运输层为应用进程之间提供端到端的逻辑通信 (但网络层是为主机之间提供逻辑通信)。 运输层还要对收到的报文进行差错检测。 运输层需要有两种不同的运输协议,即面向连 接的 TCP 和无连接的 UDP。
UDP 是面向报文的
应用层报文 应用层
UDP 首部
UDP 用户数据报的数据P 层
5.2.2 UDP 的首部格式
字节 4 源 IP 地址 字节 12 伪首部 4 目的 IP 地址 2 源端口 2 目的端口 1 0 1 2 17 UDP长度 2 检验和
2 长 度
面向报文的 UDP




发送方 UDP 对应用程序交下来的报文,在添 加首部后就向下交付 IP 层。UDP 对应用层交 下来的报文,既不合并,也不拆分,而是保留 这些报文的边界。 应用层交给 UDP 多长的报文,UDP 就照样发 送,即一次发送一个报文。 接收方 UDP 对 IP 层交上来的 UDP 用户数据 报,在去除首部后就原封不动地交付上层的应 用进程,一次交付一个完整的报文。 应用程序必须选择合适大小的报文。
2 长 度
UDP 用户数据报 发送在前
首 部


首 部

IP 数据报

计算 UDP 检验和的例子
12 字节 伪首部 10011001 00010011 → 00001000 01101000 → 153.19.8.104 10101011 00000011 → 171.3.14.11 00001110 00001011 → 全 0 17 15 00000000 00010001 → 1087 13 00000000 00001111 → 15 全0 数据 数据 数据 数据 00000100 00111111 → 00000000 00001101 → 数据 数据 数据 全 0 00000000 00001111 → 00000000 00000000 → 填充 01010100 01000101 → 01010011 01010100 → 01001001 01001110 → 01000111 00000000 → 153.19 8.104 171.3 14.11 0 和 17 15 1087 13 15 0(检验和) 数据 数据 数据 数据和 0(填充)
相关文档
最新文档