Westmont College 网络互连 Part 4 (传输协议, UDP and TCP, 协议端口)

Slides:



Advertisements
Similar presentations
第3章 网络体系结构与协议 问题 原由 计算机网络经过40年的发展, 使得计算机网络已经成为一个海量、多样化的复杂系统。计算机网络的实现需要解决很多复杂的技术问题: 支持多种通信介质;支持多厂商和异种机互联;支持人机接口等。 本章重点讨论计算机网络体系结构的形成、OSI/RM与TCP/IP模型、网络地址的形成、域名地址、子网技术等。
Advertisements

项目四:Internet基础与接入方法 第八章 应用服务器安装配置
第五章 網際網路 5-1 網際網路的歷史沿革 5-2 網際網路基本運作原理 5-3 連線媒介與連線上網 5-4 網際網路上的熱門應用
第 12 章 UDP 與 TCP.
第一章 概 述.
Chapter 12 UDP 與 TCP.
第2章 计算机网络的协议与体系结构 2.1 计算机网络体系结构的形成 2.2 协议与划分层次 2.3 计算机网络的原理体系结构
计算机网络 暨南大学计算机科学系 学年 第一学期.
第1章 概述.
数据转发过程.
Foundations of Computer Science Chapter 6 電腦網路
第 7 章 运输层 基本内容 传输层的概念,TCP/IP体系中的传输层,端口的概念,用户数据报协议UDP,传输控制协议TCP,TCP报文格式、数据的编号与确认、流量控制、拥塞控制、重传机制、TCP的连接管理。 重点掌握 TCP/IP体系中的传输控制协议TCP:TCP报文格式、数据的编号与确认、流量控制、拥塞控制、重传机制、TCP的连接管理。
網路基本概念與設定方法 林文宗 資管系助理教授
Author: Shigeki Takeuchi,Hiroyuki Koga, Katsuyoshi Iida,
Lab312.
学习目标: 1)理解包和包过滤 2)理解包过滤的方法 3)设置特殊的包过滤规则
網路概論.
传输层是整个协议层次的核心,其任务是在源机器和目标机器之间提供可靠的、性价比合理的数据传输功能,并与当前所使用的物理网络完全独立
第 12 章 UDP 與 TCP.
教师:陈有为 TCP/IP与Internet(A) 教师:陈有为
通訊協定 OSI分層模式 與 TCP/IP協定
Chapter 3 Transport Layer (傳輸層).
第3讲 网络安全协议基础 此为封面页,需列出课程编码、课程名称和课程开发室名称。
第五章 網際網路 5-1 網際網路的歷史沿革 5-2 網際網路基本運作原理 5-3 連線媒介與連線上網 5-4 網際網路上的熱門應用
TCP和UDP基本原理.
TCP报文格式.
TCP/UDP協定 10-1 TCP/UDP簡介 10-7 採用TCP或UDP 10-2 連接埠編號 10-8 UDP標頭格式
TCP/IP Protocol Suite TCP/IP協定 第二組 投影片製作by簡嘉宏 綦凱宏 林睿敏 滕孟哲.
第 2 章 TCP / IP 簡介.
在一定程度上 人类的思维产生于 简单个体之间的相互作用 ——Marvin Minsky.
Chapter 14 DHCP.
Westmont College 网络管理 SNMP
第十讲 TCP协议 协议概述 报文段格式 差错控制 流控和拥塞控制 TCP连接管理 TCP性能问题 TCP软件设计 2018/12/7
考试题型 填空题(30) 选择题(20) 名词解释(10) 问答题(24) 计算题(16) 附加题(30) 成绩核算:
第4章 OSI傳輸層.
第4讲 传输层之二 本讲目的: 本讲概述: Internet传输层的实现和实例 面向连接的传输: TCP TCP拥塞控制 拥塞控制原则
Westmont College 互联网应用软件 第二讲 (DNS, , TELNET, FTP)
计算机网络(第 5 版) 第 5 章 传输层.
计算机网络 Computer Network
Chapter 12 傳輸控制通訊協定.
计算机网络 第 7 章 运输层 课件制作人:谢希仁.
實驗目的 明瞭可靠傳輸層的基礎觀念 TCP協定下區段資料傳送的格式
NS2 – TCP/IP Simulation How-Wei Wu.
校園網路架構介紹與資源利用 主講人:趙志宏 圖書資訊館網路通訊組.
第5讲 网络层 本讲目的: 概述: 理解网络层服务原理: 因特网的实现实例 网络层的服务 路由选择原理 分层的路由选择 IP协议
第 12 章 UDP 與 TCP 著作權所有 © 旗標出版股份有限公司.
第十三章 TCP/IP 與 Internet 網路連結技術
第2讲 网络安全协议基础 此为封面页,需列出课程编码、课程名称和课程开发室名称。
第7章 传输层协议——TCP与UDP 任课教师 卢豫开.
Web Server 王宏瑾.
Westmont College 网络应用软件 第一讲 (客户-服务器 概念, 协议端口的使用, 套接字API)
Westmont College 网络的扩展 (中继器, 网桥, 交换机)
Network Application Programming(3rd Edition)
使用WireShark解析TCP封包 Computer Network Lab2.
3.1 通訊協定 3.2 開放系統參考模式(OSI) 3.3 公眾數據網路 3.4 TCP/IP通訊協定
  传输控制协议 TCP TCP TCP 发送端 接收端 应用进程 应用进程 向发送缓存 写入数据块 从接收缓存 读取数据块 … …
傳輸控制協議 /互聯網協議 TCP/IP.
1.4 计算机网络体系结构与协议 引言 网络系统的体系结构 网络系统结构参考模型ISO/OSI
Source: Journal of Network and Computer Applications, Vol. 125, No
網路安全管理 期末報告 A 許之青 24/04/2019.
第2章 網路的通訊.
大学计算机基础 5-2 计算机网络模型与协议.
網路概論 第3章 協定與模型.
Chapter 11 使用者資料包通訊協定.
2019/5/3 JAVA Socket(UDP).
指導教授:梁明章 A 許之青 國立高雄大學 2010/06/25
助教:廖啟盛 JAVA Socket(UDP) 助教:廖啟盛
網際網路原理 網際網路源起與發展歷史 1968 ARPANET 1973 TCP/IP協定 1976 乙太網路,促成LAN的發展 … DNS
第7章 传输层协议——TCP与UDP 任课教师 卢豫开.
Westmont College 网络互连 Part 2 (数据包 封装,传输, 分片, 重组)
Presentation transcript:

Westmont College 网络互连 Part 4 (传输协议, UDP and TCP, 协议端口) CS 140 Part XIII 网络互连 Part 4 (传输协议, UDP and TCP, 协议端口) Chapter 24

传输协议(TCP) 是协议栈中单独的一层 概念上处于应用层和IP层的中间 2019/4/7 Westmont College CS 140 Chapter 24

术语 IP Transport Protocols 提供计算机到计算机间的通信服务 源和目的地址都是计算机 Westmont College CS 140 术语 IP 提供计算机到计算机间的通信服务 源和目的地址都是计算机 称为 machine-to-machine的通信 Transport Protocols 提供应用程序到应用程序间的通信服务 需要扩展寻址机制来识别应用程序 称为 end-to-end 的通信 2019/4/7 Chapter 24

传输协议的功能 识别发送和接收应用程序 可选的提供如下服务 注意: 不是所有的传输协议都能提供以上的功能 “可靠”的语义: 可靠性 流控制 阻塞控制 注意: 不是所有的传输协议都能提供以上的功能 “可靠”的语义: 数据在传输时不丢失、不乱序、不被复制。 不同于“安全”。 2019/4/7

两种主要的传输协议 传输控制协议 (TCP) 用户数据报协议 (UDP) 主要不同处 应用程序接口不同 功能不同 2019/4/7

用户数据报协议 (User Datagram Protocol ,UDP) 提供不可靠(unreliable)传输服务 不可靠:意味服务时可能会有丢包、坏包等情况发生,UDP不对此负责。 只需最少的 额外负荷 计算量 通讯量 适用于:局域网应用程序 2019/4/7

UDP details 采用无连接服务模式 每条消息被封装到IP数据包中 UDP 报头中标记了 面向消息的服务接口 发送程序 接收程序 2019/4/7

标示应用程序 不能扩展IP地址 不能使用依赖于操作系统的东西 必须适用于所有的计算机系统 已经没有不用的位 Process ID Task number Job name 必须适用于所有的计算机系统 2019/4/7

标示应用程序 (续) 创造新的抽象 方法: 只用于 TCP/IP协议栈 明确区分和标示发送者和接收者 为每一个应用程序分配唯一的整数标识 称为 protocol port number 2019/4/7

协议端口 服务器 客户端 按标准使用端口 总是使用相同的端口号 使用低端口号 从协议软件得到不用的端口 使用高端口号 如何查看服务器上有哪些端口可供使用? 2019/4/7

协议端口范例 53号端口被指派用来服务于域名服务程序DNS 使用DNS的应用程序得到端口28900 UDP 数据包从应用程序发送到DNS服务器有 源端口28900 目的端口 53 当DNS服务器做出应答,数据处理后数据包有 源端口 53 目的端口 28900 2019/4/7

传输控制协议 (TCP) 英特网使用的主要传输协议 广泛地使用 提供完全可靠的传输服务 应用程序不必担心IP包的复制、丢失等问题 2019/4/7

TCP 特点 面向连接的服务 点对点 全双工通信 流接口:应用程序通过它发送持续的字节序列。 流分解成segments 每个segment被封装在IP数据包中传输 使用协议端口来识别应用程序 2019/4/7

TCP 特点总结 TCP provides a completely reliable (no data duplication or loss), connection-oriented, full-duplex stream transport service that allows two application programs to form a connection, send data in either direction, and then terminate the connection TCP 提供完全可靠的 (无数据被复制或丢失), 面向连接的, 全双工流式传输服务,允许两个应用程序建立一个连接, 双向传输数据,然后结束这一连接。每一个TCP连接均可可靠的开始、优雅地结束,所以数据在连接关闭前均可被可靠的传输。 2019/4/7

TCP和其他协议之间的关联 一台计算机上的TCP实体使用IP和另外一台计算机上的TCP实体进行通讯. 2019/4/7

明显的矛盾 IP提供不可靠的尽力传输服务 TCP 使用IP 而TCP 提供完全可靠的传输 这怎么可能? 系统重启后,如何区分上一个连接的数据包? 2019/4/7

达成可靠性 可靠的连接启动 可靠的数据传输 完美的连接关闭 2019/4/7

可靠数据传输 确认 重发 当数据到达时候,接收者返回短消息 称为 acknowledgment 消息一发送,发送者起动计时器 如果在确认消息到达前计时器终止, 发送者将重发消息 2019/4/7

重传图解 2019/4/7

在重传前TCP会等多久? 确认信息到达的时间依赖于 可能同时打开多个连接 流量条件可能迅速改变 与目的地的距离 当前的流量条件 LAN: 几毫秒 卫星? 当前的流量条件 可能同时打开多个连接 流量条件可能迅速改变 2019/4/7

要点 数据到达目的地以及返回确认所需要的延迟依赖于网络上流量和离目的地的距离. 因为TCP允许多应用程序和多个目的地进行并发通讯, 导致流量状况的不断变化,因此TCP必须处理迅速变化的多种不同延迟. 2019/4/7

解决重传问题 TCP发明以前,重传延迟使用固定值--往往较大。 最好能根据不断变化的条件而改变 TCP成功的关键 显然不好 检测并估计每个连接的往返时间 使用当前的估计来设置重发计时器 称为;自适应重传 TCP成功的关键 2019/4/7

自适应重传的图解 延时(空闲时间)依赖于对当前回路的估计 2019/4/7

TCP 流控制 接收者 宣告可用的缓冲区大小 称为 window 发送者 在确认信息到达前可以发出整个窗口大小的内容 2019/4/7

窗口宣告 每个确认信息都包含了新窗口信息 解释: 我已经收到x了,你还可以发y字节的数据. 称为 window advertisement 可以为0 (称为 closed window) 解释: 我已经收到x了,你还可以发y字节的数据. 2019/4/7

Illustration of Window Advertisement 2019/4/7

连接启动和关闭 连接启动 必须为可靠的 连接关闭 必须为完美的 难 2019/4/7

为什么启动和关闭连接困难 分段可能被 需要避免重复的“shut down”消息影响后面的连接 丢失 复制 延迟 无顺序的递送 任一方程序可以崩溃 任一方程序可以被重新启动 需要避免重复的“shut down”消息影响后面的连接 2019/4/7

TCP 启动/关闭连接问题的解决 使用三次消息交换 称为3次握手协议 是明确、可靠的启动和明确、完美的关闭连接的必要和充分条件 采用两个特殊的分段 SYN 用于启动连接 FIN 用于关闭 每次新连接,均采用一个新的32位随机数保证每一旧数据包干扰新连接。 2019/4/7

用于关闭连接的3次握手 在每个方向上发送的确认用于保证所有的数据在连接关闭前 均已到达 2019/4/7

TCP 数据段格式 所有的TCP有相同的格式 数据段分为两部分 数据 确认信息 SYN (启动) FIN (关闭) 报头 有效负载 (0或多于0字节的数据) 2019/4/7

TCP数据段格式 (续) 报头包含 协议端口号,用来识别 发送端应用 接收端应用 指明消息类型的位标记,比如 SYN FIN ACK 用于窗口宣告,确认信息等的域. 2019/4/7

TCP数据段 序列号SEQUENCE NUMBER用于指明数据在在流中什么位置 很少数据段包含OPTIONS 2019/4/7

SUMMARY 传输协议处于应用层协议和网际协议之间 TCP/IP包含两种传输协议 UDP 用户数据报协议 (UDP) 不可靠的 面向消息的接口 2019/4/7

SUMMARY (续) TCP 英特网上使用的主要传输协议 完全可靠的 面向流的接口 使用自适应重传机制 2019/4/7

SUMMARY (续) 协议端口 整数 用于识别发送和接收应用 允许多应用明确的,并发的通讯 2019/4/7 Westmont College CS 140 SUMMARY (续) 协议端口 整数 用于识别发送和接收应用 允许多应用明确的,并发的通讯 2019/4/7 Chapter 24