RPC分布式实验指导书.doc

上传人:hw****26 文档编号:2127804 上传时间:2019-04-30 格式:DOC 页数:6 大小:125KB
下载 相关 举报
RPC分布式实验指导书.doc_第1页
第1页 / 共6页
RPC分布式实验指导书.doc_第2页
第2页 / 共6页
RPC分布式实验指导书.doc_第3页
第3页 / 共6页
RPC分布式实验指导书.doc_第4页
第4页 / 共6页
RPC分布式实验指导书.doc_第5页
第5页 / 共6页
点击查看更多>>
资源描述

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

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

3、序函数 Shutdown 必须要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 编译

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

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

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

7、nt,把 Rpctest.h、Rpctest.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 文件里面)注:同上,也需在此

8、工程中添加 rpcrt4.lib 和rpcns4.lib编译生成 RpcTestclient.exe,更名为 client.exe程序源代码清单(源代码见附件)文件 简单描述3Rpctest.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 -

9、ip 192.168.1.146“来启动客户端程序并与服务器端相连。3)在 client 窗口内输入 exit 或 quit,server 窗口关闭。特别要注意的是:由于客户端的程序中有:for(i = 1; i 运行-输入 cmd-改变路径到你 client.exe 文件所在的地方(如工程目录下 debug 文件夹下)注意:如果服务器端和客户端在同一台电脑上,此语句可以不执行。即工程里编译运行程序也可以出结果。*/此处的 client.exe 就是 RpcTestclient.exe我把上面代码改为: coutpszNetworkAddr;服务器端和客户端在同一台电脑上 输入 IP127.0.0.1 是对的,有空试试分布的情况。实验结果: 服务器端和客户端在同一台电脑上2运行服务器端,结果如图(1)4图(1)3运行客户端,结果如图(2)在工程里编译运行程序,所以没有出现要我输入服务端的 IP 地址。图(2)3.客户端运行后,服务器端变为:(如图 3)5图(3)实验结果分析 服务器端运行后,一直处于监听状态,等待客户端请求。运行客户端后,客户端通过远程调用 RpcFactorial()函数,将变量 i 的值传递给服务器,服务器的远程处理函数将其求阶乘后输出

展开阅读全文
相关资源
相关搜索

当前位置:首页 > 教育教学资料库 > 课程笔记

Copyright © 2018-2021 Wenke99.com All rights reserved

工信部备案号浙ICP备20026746号-2  

公安局备案号:浙公网安备33038302330469号

本站为C2C交文档易平台,即用户上传的文档直接卖给下载用户,本站只是网络服务中间平台,所有原创文档下载所得归上传人所有,若您发现上传作品侵犯了您的权利,请立刻联系网站客服并提供证据,平台将在3个工作日内予以改正。