2第二章-分布式通信_第1页
2第二章-分布式通信_第2页
2第二章-分布式通信_第3页
2第二章-分布式通信_第4页
2第二章-分布式通信_第5页
已阅读5页,还剩16页未读 继续免费阅读

付费下载

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

1、高级操作系统北京邮电大学2022/8/11Outline第二章 分布式通信北京邮电大学第二章 分布式通信2.1 各种通信方式2.2 消息传递2.3 组通信2.4 远程调用RPC北京邮电大学2.1 各种通信方式单处理机进程间通信单处理机系统中进程间的通信无疑是利用共享存储器 分布式系统之间的通信分布式系统中,由于缺少共享存储器,系统中的通信都是基于消息传递的北京邮电大学2.1 各种通信方式分布式系统实现进程间通信注意问题无共享存储器,不能借助共享变量的方法 机器间消息传递的可靠性低于机器内信息传递的可靠性 系统内任意两台机器未必直接连接,往往需要中转 系统内的各台机器型号可能不同 通信的实现与系

2、统结构、通信线路结构、通信介质的物理性能等有密切关系北京邮电大学2.1 各种通信方式进程间通信的实现方法 可以是低级的,涉及系统调用,或者通过语言级的支持实现 进程间通信方法主要有消息传递、管道、sockets、RPC、共享内存对象之间的通信手段 CORBA、 DCOM 北京邮电大学2.1 各种通信方式选择进程间通信方法主要考虑的问题程序员对所选方法的熟悉程度 进程间通信机制的透明性,程序员知道得细节越少,出错得机会也就越少 系统所支持的方法 考虑系统的扩充 支持进程的迁移,不同文件系统的进程间通信 通信机制的标准化问题 通信机制的有效性 北京邮电大学2.2 消息传递消息传递,物理上复制要共享

3、的数据到另外一个进程的地址空间 下列情况,一般不常用消息传递 两进程不共享内存空间 不同的系统中 在同一系统中,每个进程有自己的内存 消息通常是通过OS提供的基本通信原语用消息包或帧的形式发送的。通信原语有以下两种阻塞原语(又称为同步原语)非阻塞原语(又称为异步原语)北京邮电大学2.2 消息传递阻塞原语消息被发送时,发送的进程被阻塞(即挂起),直到消息传送完毕,其后的命令才能继续执行阻塞原语实现进程不再阻塞的2种方法轮询 :利用测试原语,测试缓冲区的相关信息(状态),忙等待 中断 : 也可以在非阻塞原语种利用 如果轮询一直不成功,或者一直无中断,这样会无限阻塞下去 ,因此要有计时器,缺省的设置

4、,或者程序员控制 北京邮电大学2.2 消息传递阻塞send & receive消息传递(同步)适合于C/S模型Procedure ABeginInstructions send (B, message) / where B is the destination / waiting for acknowledgment received send acknowledgmentnext instructions EndProcedure BBeginInstructions receive (A, message) / where A is the source/ waiting for mess

5、age/ received messagenext instructions End北京邮电大学2.2 消息传递C/S模型的几个设计问题 寻址 阻塞和非阻塞原语 有缓冲和无缓冲原语 可靠和非可靠原语 管道 两进程间的通信通过内核在有限大小的缓冲区上实现,这类原语通过系统调用实现。当缓冲区满时,引起阻塞。北京邮电大学2.2 消息传递Sockets 通过网络的通信,不是共享数据结构或文件。北京邮电大学2.3 组通信组通信的用途具有冗余结构的系统 在分布式系统中查找 多副本的更新 组通信的特性 原子性 定序北京邮电大学2.3 组通信不可靠组播组通信最简单的实现方式就是不可靠组播,即简单地向每个目标发

6、送一条消息。 可靠组播一种实现方式是发送者向一个组中所有成员发送消息,然后等待每一个成员的回复。北京邮电大学2.4 远程调用RPCRPC使用过程调用实现远程通信,在传统的过程化程序设计语言环境中,它的语义类似于本地过程调用的语义,因此,它可向应用层用户提供良好的接口。Client进程 Clients Stub Servers Stub Server进程北京邮电大学2.4 远程调用RPC程序员不知道调用的是一个远程过程,还是一个本地过程,这需要有相应的支持机制,将一台计算机上语言级调用自动转化为另一台计算机上相应的语言级调用,实现变量和结果的传送。调用者阻塞,等待返回值,而不是仅仅一个确认值。与

7、各种程序设计语言一样,对参数数目和数据类型有限制北京邮电大学2.4 远程调用RPCRPC与本地调用的区别数据表示问题如果RPC是在两种异构的机器上进行的,不同机器数据表示可能不同,包括机器的字长等。指针 在不具备共享地址空间的情况下,RPC不可能允许在网络范围内传递指针。故障 调用者和被调用者都可能在调用期间发生故障 北京邮电大学2.4 远程调用RPC对于故障,由于调用者无法知道到底出现了那种情况,因此,系统需要提供一些基本的保护机制来确保RPC的正确效果。不同RPC实现方案定义的这种效果或RPC语义是有差别的,以下是几种常用的RPC调用语义。At- Most -Once (最多一次) 相同RPC的重复调用,服务器不处理。At- least -Once (至少一次) RPC将被执行至少一次,可能多次。 Last -of-Many-Call (最近调用) 每个调用包含一个标识,client接收最近调用者的返回值。北京邮电大学2.4 远程调用RPCRPC系统的实现问题RPC协议族面向连接的 面向非连接的 选择标准通用协议,还是专门为RPC设计的协议信包和报文的长度 确认停等协议(stop and wait protocol) 爆发协议(blast protocol)

温馨提示

  • 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
  • 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
  • 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
  • 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
  • 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
  • 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
  • 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

评论

0/150

提交评论