RPC分布式实验指导书.doc_第1页
RPC分布式实验指导书.doc_第2页
RPC分布式实验指导书.doc_第3页
RPC分布式实验指导书.doc_第4页
RPC分布式实验指导书.doc_第5页
免费预览已结束,剩余1页可下载查看

下载本文档

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

文档简介

此文档收集于网络,仅供学习与交流,如有侵权请联系网站删除实现一个RPC应用程序1 实验内容创建一个简单的客户机服务器的分布式应用程序,实现客户应用程序在一个远程过程调用中,向服务器传递一个整数,经过服务器端求阶乘后,将最终结果从客户机端输出。处理流程2.1开发接口,具体步骤包括:2.1.1创建接口模板在命令行方式下运行uuidgen工具,生成文件Rpctest.idlD:Program FilesMicrosoft Visual StudioCommonToolsuuidgen /I /o Rpctest.idlSolark: uuidgen /I /oRpctest.idl 书写要注意uuidgen空格/I空格/oRpctest.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); / 出现 的部分表示属性 void Shutdown(void);/ 终止服务器程序函数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 编译后生成文件 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和Rpctest_s.c放到这个项目下面,然后导入Rpctest.h Rpctest_s.c 另外两个不导入也可以的创建memstub.h(内存管理函数,memstub.h内容固定,除头文件外无需改变)2.2.2实现具体的接口函数功能新建文件Rpctest_s_f.c中实现阶乘函数;同时Rpctest_s_f.c中也包括了终止服务器程序函数Shutdown2.2.3编写服务器源程序Rpctest_s.c 一点都不改变。添加一个新文件main.cpp 里面放main()函数. main()函数里代码负责建立RPC接口的捆绑, 并用名称服务程序来注册它们及侦听RPC请求. 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环境下建一个空项目Rpctestclient,把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文件里面)注:同上,也需在此工程中添加rpcrt4.lib和rpcns4.lib编译生成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)在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)3 运行客户端,结果如图(2)在工程里编译运行程序,所以没有出现要

温馨提示

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

评论

0/150

提交评论