- 1、有哪些信誉好的足球投注网站(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
分布式系统的重要不言而喻, 下面是使用rpcgen工具构建一个分布式程序的例子, 其实主要就是TCP/IP进行网际互联卷3上面的那个例子, 就是下面这本书. 另外还参考了分布式系统 原理与范例这本书, 即Andrew S. Tanenbaum写的这本, 这本书是学习分布式的必读书之一. 相当不错. 整个文章分为三部分, 第一部分是对RPC(远程过程调用)的一个介绍, 第二部分是对使用rpcgen构建分布式程序的一个介绍, 第三部分是使用rpcgen构建分布式程序的详细步骤.可以先按照第三部分的步骤自己先试试, 如果有兴趣再回过头来看它的介绍.另外, 我写的这个只是一个入门, 如果以后有机会再详细地讨论一下内部的机理. 事情总是一步一步来的. 一. RPC概念1.1 介绍 在中间件的实现中,引入了远程过程调用RPC(Remote Procedure Call)的概念。同时,许多分布式系统是基于进程间的显式消息交换的,然而消息的发送和接收过程无法隐藏通信的存在,而通信的隐藏对于在分布式系统中实 现访问透明性是极为重要的。因此这个问题在很长一段时间内都没有找到合适的解决办法,后来Birrel和Nelson在1984年的一篇论文中引入了一套 与传统方法截然不同的通信处理手段。他们认为应该允许程序调用位于其它机器上的进程。当机器A上的进程调用B上的进程时,A上的调用进程被挂起,而B上的 被调用进程开始执行。调用方可以通过使用参数将信息传送给被调用方,然后可以通过传回的结果得到信息。编程人员看不到任何消息传递过程。这种方法就称为远 程过程调用RPC。目前,RPC作为一种广泛使用的技术,已成为许多分布式系统的基础。1.2 构建分布式程序的两种模式在设计分布式应用时,程序员可以使用下列两种方法之一:面向通信的设计 由通信协议开始。设计报文格式和语法,指明对每个传入报文将如何反应以及如何产生每个外发报文,以此来设计客户和服务器各构件。面向应用的设计 由应用开始。设计常规的应用程序来解决问题。构建并测试可在单台机器上运行的常规程序的工作版本。将这个程序划分成两个或多个程序片,加入通信协议以允许每片程序在单独的计算机上执行。 远程过程调用模型使用面向应用的方法,它强调的是所要解决的问题而不是所需要的通信。利用远程过程调用,程序员首先设计一个解决问题的常规程序,接着将其 划分成若赶干片,这些程序片运行在两台或更多的计算机上。程序员可遵循良好的设计原则,以便使代码模块化并且可维护。 在理想的情况下,远程过程调用提供的不只是抽象上的概念。它允许程序员在将一个程序划分成若干片之前,先构建,编译和测试一个解决该问题的常规程序的版 本,以便确保能够正确解决问题。不但如此,因为RPC以方法调用为边界划分程序,所以将程序划分为本地部分和远程部分并不会引起程序结构的很大变化。实际 上,将某些过程从一个程序转移到远程机器上时,有可能不需要改变。1.3 常规过程调用的概念性模型 如下图所示,为常规的程序调用。本地过程调用.jpg1.4 远程过程调用模型 远程过程调用模型使用了和常规程序一样的过程抽象,但是它允许一个过程的边界跨越两台计算机。如下图所示。远程过程调用.jpg1.5 常规过程调用的执行和返回 程序从一个主程序开始执行,并一直继续下去,直到遇到一个过程调用。这个调用使程序的执行转入到某个指定的代码处继续执行。常规过程调用的执行流程如下图所示:常规过程调用.jpg1.6 分布式系统的过程模型 在分布式系统中,其中的某个过程有可能在另外的机器上,因此,其调用过程模型如下图如示:分布式中的过程调用.jpg1.7 客户-服务器和RPC之间的对比 远程过程调用允许程序员以一种他所熟悉的环境来思考客户和服务器的交互,如同常规的过程调用,远程过程调用把控制权传递给被调用的进程。也像常规过程调用一样,在调用进程中,系统把调用过程的执行挂起。而只允许被调用过程执行。 当远程程序发出响应时,这对应于在常规过程调用中执行return。控制权返回给调用者,被调用过程停止执行。嵌套的过程调用的想法也可应用到远程过程调用。远程过程调用也许要调用另一个远程过程。如上图所示。二. 分布式程序的生成原理 RPC的实现包括一个工具,它自动地生成实现分布式程序所需要的大多数代码。这个工具叫做rpcgen,它读取一个规约文件作为输入,生成C的源文件作为 输出。规范文件包含常量,全局数据类型,全局数据以及远程过程(包括过程参数和结果类型)的声明。rpcgen产生的代码包含了实现客户和服务器程序所需 要的大部分源代码。具体地说,rpcgen包括参数整理,发送RPC报文,把传入调用分派到正确的过程
您可能关注的文档
最近下载
- 【00015】英语(二)自学教程.pdf VIP
- 城市轨道交通站务管理(化工社版):任务3.4.ppt VIP
- 城市轨道交通站务管理(化工社版):任务3.ppt VIP
- 运用HFMEA品管工具预防老年住院患者跌倒发生率(护理部临床多病区)医院品质管理案例大赛获奖案例.pptx
- 城市轨道交通站务管理(化工社版):任务3.1.ppt VIP
- [作物栽培学课件13总论课件精品.ppt
- 城市轨道交通站务管理(化工社版):任务2.4.ppt VIP
- 城市轨道交通站务管理(化工社版):任务2.3.ppt VIP
- 城市轨道交通站务管理(化工社版):任务2.ppt VIP
- 城市轨道交通站务管理(化工社版):任务2.1.ppt VIP
文档评论(0)