使用rpcgen构建分布式程序的一个简单例子

本文介绍了远程过程调用RPC的概念,强调了其在分布式系统中的重要性,并详细阐述了使用rpcgen构建分布式程序的过程,包括从概念理解、程序划分、规约文件创建到rpcgen工具的使用和编译链接的步骤。
摘要由CSDN通过智能技术生成
使用rpcgen构建分布式程序的一个简单例子

一. RPC概念
1.1 介绍
        在中间件的实现中,引入了远程过程调用RPC(Remote Procedure Call)的概念。同时,许多分布式系统是基于进程间的显式消息交换的,然而消息的发送和接收过程无法隐藏通信的存在,而通信的隐藏对于在分布式系统中实现访问透明性是极为重要的。因此这个问题在很长一段时间内都没有找到合适的解决办法,后来Birrel和Nelson在1984年的一篇论文中引入了一套与传统方法截然不同的通信处理手段。他们认为应该允许程序调用位于其它机器上的进程。当机器A上的进程调用B上的进程时,A上的调用进程被挂起,而B上的被调用进程开始执行。调用方可以通过使用参数将信息传送给被调用方,然后可以通过传回的结果得到信息。编程人员看不到任何消息传递过程。这种方法就称为远程过程调用RPC。目前,RPC作为一种广泛使用的技术,已成为许多分布式系统的基础。
1.2 构建分布式程序的两种模式
在设计分布式应用时,程序员可以使用下列两种方法之一:
面向通信的设计
        由通信协议开始。设计报文格式和语法,指明对每个传入报文将如何反应以及如何产生每个外发报文,以此来设计客户和服务器各构件。
面向应用的设计
        由应用开始。设计常规的应用程序来解决问题。构建并测试可在单台机器上运行的常规程序的工作版本。将这个程序划分成两个或多个程序片,加入通信协议以允许每片程序在单独的计算机上执行。
        远程过程调用模型使用面向应用的方法,它强调的是所要解决的问题而不是所需要的通信。利用远程过程调用,程序员首先设计一个解决问题的常规程序,接着将其划分成若赶干片,这些程序片运行在两台或更多的计算机上。程序员可遵循良好的设计原则,以便使代码模块化并且可维护。
        在理想的情况下,远程过程调用提供的不只是抽象上的概念。它允许程序员在将一个程序划分成若干片之前,先构建,编译和测试一个解决该问题的常规程序的版本,以便确保能够正确解决问题。不但如此,因为RPC以方法调用为边界划分程序,所以将程序划分为本地部分和远程部分并不会引起程序结构的很大变化。实际上,将某些过程从一个程序转移到远程机器上时,有可能不需要改变。
1.3 常规过程调用的概念性模型
        如下图所示,为常规的程序调用。
本地过程调用 
1.4 远程过程调用模型
        远程过程调用模型使用了和常规程序一样的过程抽象,但是它允许一个过程的边界跨越两台计算机。如下图所示。
远程过程调用 
1.5 常规过程调用的执行和返回
        程序从一个主程序开始执行,并一直继续下去,直到遇到一个过程调用。这个调用使程序的执行转入到某个指定的代码处继续执行。常规过程调用的执行流程如下图所示:
常规过程调用及返回 
1.6 分布式系统的过程模型
        在分布式系统中,其中的某个过程有可能在另外的机器上,因此,其调用过程模型如下图如示:
分布式中的过程调用及返回 
1.7 客户-服务器和RPC之间的对比
        远程过程调用允许程序员以一种他所熟悉的环境来思考客户和服务器的交互,如同常规的过程调用,远程过程调用把控制权传递给被调用的进程。也像常规过程调用一样,在调用进程中,系统把调用过程的执行挂起。而只允许被调用过程执行。
        当远程程序发出响应时,这对应于在常规过程调用中执行return。控制权返回给调用者,被调用过程停止执行。嵌套的过程调用的想法也可应用到远程过程调用。远程过程调用也许要调用另一个远程过程。如上图所示。

二. 分布式程序的生成原理
        RPC的实现包括一个工具,它自动地生成实现分布式程序所需要的大多数代码。这个工具叫做rpcgen,它读取一个规约文件作为输入,生成C的源文件作为输出。规范文件包含常量,全局数据类型,全局数据以及远程过程(包括过程参数和结果类型)的声明。rpcgen产生的代码包含了实现客户和服务器程序所需要的大部分源代码。具体地说,rpcgen包括参数整理,发送RPC报文,把传入调用分派到正确的过程,发送应答,在参数和结构的外部表示和本地数据表示之间进行转换。rpcgen的输出与应用程序和程序员编写的少数文件相结合后,便产生出了完整的客户和服务器程序。
        rpcgen读取输入文件,该文件包含有对远程过程的说明。它产生四个输出文件,每个文件都包含有源代码,如果输入的文件(即规约文件)具有名字q.x, 则输出的文件如下所示:
q.h:常量和类型的声明
q_xdr.c XDR过程调用
q_clnt.c 客户端的通信接口
q_svc.c 服务器端的通信接口
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值