《RPC分布式实验指导书.doc》由会员分享,可在线阅读,更多相关《RPC分布式实验指导书.doc(6页珍藏版)》请在课桌文档上搜索。
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
2、和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
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、Rpctes
4、t_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
5、.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环境下编译和服务器端程序,最终生成Rpctestserv
6、er.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 另外两个不导
7、入也可以的创建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.a
8、cf 属性配置文件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
9、.exe文件所在的地方(如工程目录下debug文件夹下)注意:如果服务器端和客户端在同一台电脑上,此语句可以不执行。即工程里编译运行程序也可以出结果。*/此处的client.exe 就是 RpcTestclient.exe我把上面代码改为: cout请输入服务器IP地址pszNetworkAddr;服务器端和客户端在同一台电脑上 输入IP127.0.0.1 是对的,有空试试分布的情况。实验结果: 服务器端和客户端在同一台电脑上2 运行服务器端,结果如图(1)图(1)3 运行客户端,结果如图(2)在工程里编译运行程序,所以没有出现要我输入服务端的IP地址。图(2)3.客户端运行后,服务器端变为:(如图3)图(3)实验结果分析 服务器端运行后,一直处于监听状态,等待客户端请求。运行客户端后,客户端通过远程调用RpcFactorial()函数,将变量i的值传递给服务器,服务器的远程处理函数将其求阶乘后输出6 / 6