RPC分布式实验指导书_第1页
RPC分布式实验指导书_第2页
RPC分布式实验指导书_第3页
RPC分布式实验指导书_第4页
RPC分布式实验指导书_第5页
已阅读5页,还剩2页未读 继续免费阅读

下载本文档

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

文档简介

1、实现一个RPC应用程序 实验内容创建一个简单的客户机服务器的分布式应用程序, 实现客户应用程序在 一个远程过程调用中, 向服务器传递一个整数, 经过服务器端求阶乘后, 将最终 结果从客户机端输出。处理流程2.1 开发接口,具体步骤包括:2.1.1 创建接口模板在命令行方式下运行 uuidgen 工具,生成文件 Rpctest.idlD:Program FilesMicrosoft Visual StudioCommonToolsuuidgen /I /o Rpctest.idlSolark: uuidgen /I /oRpctest.idl书写要注意uuidgen空格/I空格/oRpctest

2、.idl其中参数o和Rpctest.idl 中间没有空格。执行后, Rpctest.idl 中内容为:uuid(698cb6d9-df44-41a7-a66f-addc7e731fe1),version(1.0),interface INTERFACENAME2.1.2替换 Rpctest.idl 中接口的定义(原来是:in terface INTERFACENAME 改为: interface Rpctest / 远程过程调用的求阶乘函数long RpcFactorial(in long nVal); /出现 的部分表示属性void Shutdown(void);/ 终止服务器程序函数 Sh

3、utdown 必须要2.1.3使用文本编辑器编写ACF(属性配置文件),Rpctest.acfimplicit_handle (handle_t Rpctest_IfHandle)/ 这个必须要,用来连接服务器和客户端的interface Rpctest / solark :要和 idl 中接口名称一致2.1.4使用MIDL编译器进行编译(注:Rpctest.idl 和Rpctest.acf 都放Bin目录下) 在命令行方式下运行 MIDL.EXE,D:Program FilesMicrosoft Visual StudioVC98Binmidl Rpctest.idl 编译后生成文件 Rpc

4、test.h 、Rpctest_c.c 、Rpctest_s.cSolark :此处还有一个办法: 创建一个空的工程,如 RpcTest 将编辑好的Rpctest.idl 文件添加至RpcTest项目中。然后,直接进行编译。这时就可以看到 RpcTest 项目的生成目录下有了 Rpctest.h 、Rpctest_c.c 、 Rpctest_s.c 三个文件。2.2. 开发服务器程序,具体步骤包括:2.2.1VC 环境下 建一个空工程( win32 console application ) Rpctestserver ,把 Rpctest.h 、Rpctest.idl 、Rpctest.ac

5、f 和 Rpctest_s.c 放到这个项目下面, 然后导入 Rpctest.h Rpctest_s.c 另外两个不导入也可以的创建memstub.h(内存管理函数,memstub.h内容固定,除头文件外无需改变)2.2.2 实现具体的接口函数功能新建文件 Rpctest_s_f.c 中实现阶乘函数;同时 Rpctest_s_f.c 中也包括了终止 服务器程序函数 Shutdown223编写服务器源程序Rpctest_s.c 点都不改变。添加一个新文件main.cpp里面放main()函数.main()函数里代码负责建立 RPC接口的捆绑,并用名称服务程序来注册它们及 侦听RPC请求.Serv

6、er 端也与RPC run time连接.2.2.4在VC环境下编译和链接服务器端程序,最终生成Rpctestserver.exe 文件(在Debug文件里面)注:在 VC中 Project-Settings-Link中添加两个 RPC运行库:rpcrt4.lib和 rpc ns4.lib编译工程生成 Rpctest server .exe,更名为 server.exe(rpcns4.lib名字服务函数;rpcrt4.lib 3 2位Windows运行期函数)3.开发客户机程序,具体步骤包括:2.3.1VC 环境下建一个空项目 Rpctestclient,把 Rpctest.h、Rpctest

7、.idl 、Rpctest.acf 和Rpctest_c.c 放到这个项目下面,然后导入Rpctest.h Rpctest_c.c 另外两个不导入也可以的创建memstub.h(内存管理函数,memstub.h内容固定,除头文件外无需改变)2.3.2Rpctest_s.c 一点都不改变。添加一个新文件 main_c.cpp里面放main()函数。main()函数里代码负责连接服务器和调用远程函数2.3.3在VC环境下编译和链接客户端程序,最终生成Rpctestclient.exe 文件(在Debug文件里面)注:同上,也需在此工程中添加 rpcrt4.lib 和rpcns4.lib 编译生成

8、RpcTestclient .exe,更名为 client.exe文件Rpctest.idl Rpctest.acf Rpctest.h Rpctest_c.c程序源代码清单(源代码见附件)简单描述接口定义语言文件属性配置文件头文件客户端存根Rpctest_s.c main_c.cpp main.cpp Rpctest_s_f.c服务器端存根客户端主程序服务器端主程序 接口函数具体实现运行结果1执行过程1) 首先运行 server.exe 。2) 而后,在 client.exe 所在的目录下用命令行client.exe -ip 192.168.1.146来启动客户端程序并与服务器端相连。3)在

9、 client 窗口内输入 exit 或 quit ,server 窗口关闭。 特别要注意的是: 由于客户端的程序中有:for(i = 1; i 运行- 输入 cmd- 改变路径到你client.exe 文件所在的地方(如工程目录下debug文件夹下) 注意:如果服务器端和客户端在同一台电脑上, 此语句可以不执行。 即工程里编 译运行程序也可以出结果。 */ 此处的 client.exe 就是 RpcTestclient .exe 我把上面代码改为:cout请输入服务器IP地址pszNetworkAddr;服务器端和客户端在同一台电脑上 输入 IP127.0.0.1 是对的,有空试试分布 的情况。实验结果 : 服务器端和客户端在同一台电脑上2运行服务器端,结果如图 (1)在工程里编译运行程

温馨提示

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

评论

0/150

提交评论