王占全zhqwangecusteducn.ppt
《王占全zhqwangecusteducn.ppt》由会员分享,可在线阅读,更多相关《王占全zhqwangecusteducn.ppt(127页珍藏版)》请在得力文库 - 分享文档赚钱的网站上搜索。
1、王占全zhqwangecusteducn Still waters run deep.流静水深流静水深,人静心深人静心深 Where there is life,there is hope。有生命必有希望。有生命必有希望n引入传输层的原因n消除网络层的不可靠性;n提供从源端主机到目的端主机的可靠的、与实际使用的网络无关的与端口相关的信息传输。第7章 传输层为什么要引入传输层2它是网络体系结构承上启下的一层它是网络体系结构承上启下的一层,在网络层与应用层之间在网络层与应用层之间。物理层网络层传输层应用层数据链路层面向信息处理面向通信用户功能网络功能本章学习要求本章学习要求:n网络环境中分布式进程
2、通信的基本概念网络环境中分布式进程通信的基本概念n进程相互作用的进程相互作用的Client/Server模型模型n传输层的基本功能与服务质量传输层的基本功能与服务质量n用户数据报协议用户数据报协议UDP n传输控制协议传输控制协议TCP 47.1.1 单机系统中的进程通信方法 n进程和进程通信是操作系统中的一个最基本的进程和进程通信是操作系统中的一个最基本的概念;概念;n程序是一个在时间上按照严格次序的前后相继程序是一个在时间上按照严格次序的前后相继的操作序列,是一个静态的概念;的操作序列,是一个静态的概念;n进程是一个动态的概念,它是一个程序对某个进程是一个动态的概念,它是一个程序对某个数据
3、集的执行过程;数据集的执行过程;7.1 网络环境中分布式进程通信的基本概念5n正在运行的进程叫做运行态;正在运行的进程叫做运行态;n等待分配等待分配CPUCPU的进程叫做就绪态;的进程叫做就绪态;n等待其它的条件的进程叫做等待态;等待其它的条件的进程叫做等待态;n进程状态反映出进程执行过程的变化;进程状态反映出进程执行过程的变化;n要保证系统正常地工作,操作系统必须对进程要保证系统正常地工作,操作系统必须对进程的创建、撤消与状态转换进行控制;的创建、撤消与状态转换进行控制;n从进程的观点看,操作系统的核心则是控制和从进程的观点看,操作系统的核心则是控制和协调这些进程的运行,解决进程之间的通信。
4、协调这些进程的运行,解决进程之间的通信。6在解决单机环境下操作系统的进程通信中:在解决单机环境下操作系统的进程通信中:n目前常用的通信机制有消息机制、管道通信等目前常用的通信机制有消息机制、管道通信等nBSD UNIX 引入了管道(引入了管道(pipe)、)、命名管道命名管道(named pipe)和软中断信号(和软中断信号(signal)机制;机制;nAT&T UNIX引入了消息(引入了消息(message)、)、共享存储区共享存储区(shared memory)和信号量(和信号量(semaphore)等;等;nUNIX系统的消息、共享存储区和信号量统称为进程系统的消息、共享存储区和信号量统
5、称为进程通信(通信(inter process communication,IPC)机制;机制;7网络环境中分布式进程通信的特点用一句最简单的话去描述计算机网络,那就是用一句最简单的话去描述计算机网络,那就是:n计算机网络是分布在不同地理位置的多台独立计算机网络是分布在不同地理位置的多台独立的计算机系统的集合;的计算机系统的集合;n“独立的计算机系统独立的计算机系统”意味着联网的每一台计意味着联网的每一台计算机的操作与资源是由自己的操作系统所管理;算机的操作与资源是由自己的操作系统所管理;n用户共享的网络资源及网络所能提供的服务功用户共享的网络资源及网络所能提供的服务功能最终是通过网络环境中的
6、分布式进程通信来能最终是通过网络环境中的分布式进程通信来实现的。实现的。7.1.2 网络环境中分布式进程通信的基本概念8n网络环境中的进程通信与单机系统内部的进程网络环境中的进程通信与单机系统内部的进程通信的主要区别:通信的主要区别:网络中主机的高度自治性;网络中主机的高度自治性;n不是在同一个主机系统之中,没有一个统一的不是在同一个主机系统之中,没有一个统一的高层进行控制与管理;高层进行控制与管理;n网络中一台主机对其它主机的网络中一台主机对其它主机的 活动状态活动状态 位于其它主机系统中的各个进程状态位于其它主机系统中的各个进程状态 这些进程什么时间参与网络活动这些进程什么时间参与网络活动
7、 希望与网络中哪一台主机的什么进程通信希望与网络中哪一台主机的什么进程通信 对方的协议类型对方的协议类型一概无从知道一概无从知道91.网络环境中分布式进程通信需要解决网络环境中分布式进程通信需要解决:n进程命名与寻址方法进程命名与寻址方法n多重协议的识别多重协议的识别n进程间相互作用的模式进程间相互作用的模式102.网络环境中进程标识网络环境中进程标识n在一台计算机中,不同的进程用进程号或进程在一台计算机中,不同的进程用进程号或进程标识(标识(process ID)惟一地标识出来惟一地标识出来 n网络环境中完整的进程标识应该是:网络环境中完整的进程标识应该是:本地主机地址本地主机地址-本地进程
8、标识本地进程标识 远程主机地址远程主机地址-远程进程标识远程进程标识n进程地址也叫做端口号(进程地址也叫做端口号(port number)113.多重协议的识别n很多系统的网络协议是不一样很多系统的网络协议是不一样12131415161718n网络环境中一个完整的进程通信标识需要一个网络环境中一个完整的进程通信标识需要一个五元组来表示:五元组来表示:协议协议 本地地址本地地址 本地端口号本地端口号 远地地址远地地址 远地端口号远地端口号n在在UNIX操作系统中操作系统中:三元组又叫做半相关三元组又叫做半相关half-association 五元组叫做一个相关五元组叫做一个相关associati
9、on19n1.Client/Server模型的基本概念模型的基本概念n网络环境中进程通信要解决的进程间相互作用的模式网络环境中进程通信要解决的进程间相互作用的模式;n在在TCP/IPTCP/IP协议体系中,进程间的相互作用采用客户协议体系中,进程间的相互作用采用客户/服务服务器器(Client/Server)Client/Server)模型模型;n客户与服务器分别表示相互通信的两个应用程序的进程客户与服务器分别表示相互通信的两个应用程序的进程;n客户向服务器发出服务请求,服务器响应客户的请求,客户向服务器发出服务请求,服务器响应客户的请求,提供客户机所需要的网络服务提供客户机所需要的网络服务;
10、7.1.3 进程间相互作用模式:Client/Server模型20n网络中每台联网的计算机既为本地用户提供服网络中每台联网的计算机既为本地用户提供服务,也为网络的其它主机的用户提供服务务,也为网络的其它主机的用户提供服务;n每台联网的计算机的硬件、软件与数据资源应每台联网的计算机的硬件、软件与数据资源应该既是本地用户可以使用的资源,也是网络的该既是本地用户可以使用的资源,也是网络的其它主机的用户可以共享的资源其它主机的用户可以共享的资源;n每一项网络服务都是对应一个每一项网络服务都是对应一个“服务程序服务程序”进进程程;n“服务程序服务程序”进程要为每一个获准的网络用户进程要为每一个获准的网络
11、用户请求执行一组规定的动作,以满足用户网络资请求执行一组规定的动作,以满足用户网络资源共享的需要源共享的需要;212.为什么要采用客户机/服务器模型?一一 网络资源分布的不均匀性网络资源分布的不均匀性n网络资源分布的不均匀性表现在硬件、软件和数据等三网络资源分布的不均匀性表现在硬件、软件和数据等三个方面个方面;n网络资源分布的不均匀性是客观存在的,同时也是网络网络资源分布的不均匀性是客观存在的,同时也是网络应用系统设计者的设计思想的体现应用系统设计者的设计思想的体现;n“资源共享资源共享”就是因为网络不同结点之间在硬件配置、就是因为网络不同结点之间在硬件配置、计算能力、存储能力,以及数据分布等
12、方面存在着差距计算能力、存储能力,以及数据分布等方面存在着差距与不均匀性;与不均匀性;n能力强、资源丰富的充当服务器,能力弱或需要某种资能力强、资源丰富的充当服务器,能力弱或需要某种资源的成为客户。源的成为客户。22二二 网络环境中进程通信的异步性网络环境中进程通信的异步性 n分布在不同主机系统中的进程什么时间发分布在不同主机系统中的进程什么时间发出通信请求,希望和哪一台主机的哪一个出通信请求,希望和哪一台主机的哪一个进程通信,以及对方进程是否能接受通信进程通信,以及对方进程是否能接受通信请求是不确定的请求是不确定的;n网络分布式进程之间不存在一个高层的调网络分布式进程之间不存在一个高层的调度
13、与协调度与协调;n必须要建立一个体制,为准备通信的进程必须要建立一个体制,为准备通信的进程之间建立起连接,在进程交换数据的过程之间建立起连接,在进程交换数据的过程中维护连接,为数据交换提供同步。中维护连接,为数据交换提供同步。23n客客 户户 一次进程通信中发起的一方;一次进程通信中发起的一方;n服务器服务器 接受进程通信的请求,提供服务的接受进程通信的请求,提供服务的 一方;一方;n每一次通信由客户进程随机启动;每一次通信由客户进程随机启动;n服务器进程处于等待状态,及时响应客户服务服务器进程处于等待状态,及时响应客户服务请求。请求。247.1.4 进程通信中Client/Server模型实
14、现方法n客户机客户机/服务器模型的工作实质是服务器模型的工作实质是“请求驱动请求驱动”;n在网络环境中,客户进程发出请求完全随机。在网络环境中,客户进程发出请求完全随机。在同一个时刻,可能有多个客户进程向一个服在同一个时刻,可能有多个客户进程向一个服务器发出服务请求;务器发出服务请求;n为了实现服务器的功能,在服务器的设计中要为了实现服务器的功能,在服务器的设计中要解决服务器的:解决服务器的:n 并发请求处理能力并发请求处理能力 并发服务器的进程标识并发服务器的进程标识 服务器安全服务器安全实现它们需要注意什么问题?实现它们需要注意什么问题?25解决服务器处理并发请求的基本方案解决服务器处理并
15、发请求的基本方案:n设计一个并发服务器设计一个并发服务器n采用重复服务器的方法采用重复服务器的方法26并发服务器(concurrent server)n并发服务器的核心是使用一个并发服务器的核心是使用一个守护程序守护程序(daemon););n守护程序在系统启动的时候随之启动,在没有客户的服守护程序在系统启动的时候随之启动,在没有客户的服务请求到达时,并发服务器处于等待状态务请求到达时,并发服务器处于等待状态;n一旦客户机的服务请求到达,服务器根据客户的服务请一旦客户机的服务请求到达,服务器根据客户的服务请求的进程号,去激活相应的子进程,而服务器回到等待求的进程号,去激活相应的子进程,而服务器
16、回到等待状态;状态;n并发服务器叫做主服务器(并发服务器叫做主服务器(master),),把子服务器叫做把子服务器叫做从服务器(从服务器(slave););n主服务器必须拥有一个全网公认的进程地址;主服务器必须拥有一个全网公认的进程地址;n网络中的客户进程可以根据服务器进程的公认地址,向网络中的客户进程可以根据服务器进程的公认地址,向服务器提出服务请求。服务器提出服务请求。27客户与并发服务器建立传输连接的过程28重复服务器(interative server)n通过设置一个请求队列来存储客户机的服务请通过设置一个请求队列来存储客户机的服务请求;求;n服务器采用先来先服务的原则来顺序处理客户服
17、务器采用先来先服务的原则来顺序处理客户机的服务请求。机的服务请求。29比较并发服务器并发服务器:n并发服务器可以处理多个客户的服务请求;并发服务器可以处理多个客户的服务请求;n从服务器不依赖主服务器而独立处理客户服务请求;从服务器不依赖主服务器而独立处理客户服务请求;n不同的从服务器可以分别处理不同的客户的服务请求;不同的从服务器可以分别处理不同的客户的服务请求;n系统的实时性好;系统的实时性好;重复服务器重复服务器:n处理客户的服务请求的数量受到请求队列长度的限制,处理客户的服务请求的数量受到请求队列长度的限制,但可以有效地控制请求处理的时间但可以有效地控制请求处理的时间;并发服务器适应于面
18、向连接的服务类型;并发服务器适应于面向连接的服务类型;重复服务器适应于无连接的服务类型。重复服务器适应于无连接的服务类型。30讨论n服务器是一个用来提供某种服务的,有特殊权限服务器是一个用来提供某种服务的,有特殊权限的专用程序;的专用程序;n服务器程序在网络中一台计算机上运行,接受来服务器程序在网络中一台计算机上运行,接受来自远程客户的服务请求,提供一种服务;自远程客户的服务请求,提供一种服务;n服务器程序需要硬件配置较高的计算机和操作系服务器程序需要硬件配置较高的计算机和操作系统的支持;统的支持;n客户客户/服务器是软件设计中进程间相互作用关系服务器是软件设计中进程间相互作用关系的模型。的模
19、型。317.2 传输层的基本功能7.2.1 传输层的端传输层的端-端通信端通信 传输层与网络层的区别在那里?32传输层协议和网络层协议的主要区别 应用进程应用进程IP协议的作用范围(提供主机之间的逻辑通信)TCP和UDP协议的作用范围(提供进程之间的逻辑通信)因特网主机进程3334n网络层及以下的各层实现了网络中主机之间的网络层及以下的各层实现了网络中主机之间的通信,但是主机通信不是最终的目的通信,但是主机通信不是最终的目的;n计算机网络最本质的活动是分布在不同地理位计算机网络最本质的活动是分布在不同地理位置的主机之间的进程通信,以实现各种网络服置的主机之间的进程通信,以实现各种网络服务功能务
20、功能;n设置传输层的主要目的就是要实现分布式进程设置传输层的主要目的就是要实现分布式进程通信。通信。n传输层的传输单元是报文传输层的传输单元是报文传输层35应用进程之间的通信n应用进程之间的通信又称为端到端的通信。n传输层的一个很重要的功能就是复用和分用。应用层不同进程的报文通过不同的端口向下交到传输层,再往下就共用网络层提供的服务。n“传输层提供应用进程间的逻辑通信”。“逻辑通信”的意思是:传输层之间的通信好像是沿水平方向传送数据。但事实上这两个传输层之间并没有一条水平方向的物理连接。367.2.2 传输层协议的基本功能1.传输层在协议层次结构中的位置传输层在协议层次结构中的位置n传输层的目
21、标是向应用层应用程序进程之间的通信,提传输层的目标是向应用层应用程序进程之间的通信,提供有效、可靠、保证质量的服务供有效、可靠、保证质量的服务;n传输层在网络分层结构中起着承上启下的作用,通过执传输层在网络分层结构中起着承上启下的作用,通过执行传输层协议,屏蔽通信子网在技术、设计上的差异和行传输层协议,屏蔽通信子网在技术、设计上的差异和服务质量的不足,向高层提供一个标准的、完善的通信服务质量的不足,向高层提供一个标准的、完善的通信服务服务;n从通信和信息处理的角度看,应用层是面向信息处理的,从通信和信息处理的角度看,应用层是面向信息处理的,而传输层是为应用层提供通信服务的。而传输层是为应用层提
22、供通信服务的。372.传输协议数据单元n传输层之间传输的报文叫做传输协议数据单元传输层之间传输的报文叫做传输协议数据单元(Transport Protocol Unit,TPDU););nTPDU有效载荷是应用层的数据。有效载荷是应用层的数据。383.传输层协议运行环境的特点n1 传输层连接建立过程比较复杂n2 传输层之间数据报文传送过程比较复杂n因此必须研究该层的差错控制、流量控制等问题,寻找合适的方法,制定相应的协议。394.传输层的主要功能 n传输层为应用进程之间提供端到端的逻辑通信(但网络层是为主机之间提供逻辑通信)。n传输层某些协议还要对收到的报文进行差错检测、流量控制、拥塞控制等。
23、n传输层需要有两种不同的运输协议,即面向连接的 TCP 和无连接的 UDP。40传输层与其上下层之间的关系的表示法 运输实体运输实体运输协议传输层层接口运输服务用户(应用层实体)运输服务用户(应用层实体)层接口网络层(或网际层)应用层主机A主机B传输层服务访问点TSAP网络层服务访问点NSAP41427.2.3 网络服务与服务质量QoS 服务(服务(Service)n网络层次结构中,各层之间有严格的依赖关系网络层次结构中,各层之间有严格的依赖关系各层次的分工和协作集中地体现在相邻层之间各层次的分工和协作集中地体现在相邻层之间的界面上;的界面上;n服务是描述相邻层之间关系的重要概念;服务是描述相
24、邻层之间关系的重要概念;n网络服务体现在低层向相邻上层提供的一组操网络服务体现在低层向相邻上层提供的一组操作;作;n低层是服务提供者,高层是服务的用户。低层是服务提供者,高层是服务的用户。43衡量服务质量衡量服务质量QoS的主要指标的主要指标n连接建立延迟连接建立延迟/连接连接释放释放延迟延迟n连接建立连接建立/释放失败概率释放失败概率n传输时延传输时延n吞吐率吞吐率n残余误码率残余误码率n安全保护安全保护n优先级优先级n恢复功能恢复功能 44连接建立延迟连接建立延迟n从传输服务用户要求建立连接到收到连接确认从传输服务用户要求建立连接到收到连接确认之间所经历的时间;之间所经历的时间;n它包括了
25、远端传输实体的处理延迟;它包括了远端传输实体的处理延迟;n连接建立延迟越短,服务质量越好。连接建立延迟越短,服务质量越好。连接建立失败的概率连接建立失败的概率n在最大连接建立延迟时间内,连接未能建立的在最大连接建立延迟时间内,连接未能建立的可能性;可能性;n由于网络拥塞,缺少缓冲区或其他原因造成的由于网络拥塞,缺少缓冲区或其他原因造成的失败。失败。45吞吐率吞吐率n吞吐率是在某个时间间隔内测得传输用户数据吞吐率是在某个时间间隔内测得传输用户数据的字节数的字节数,或者每秒传输的用户数据的字节数。或者每秒传输的用户数据的字节数。n每个传输方向分别用各自的吞吐率来衡量。每个传输方向分别用各自的吞吐率
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- 王占全 zhqwangecusteducn
限制150内