您好,欢迎访问三七文档
当前位置:首页 > 建筑/环境 > 工程监理 > RPC分布式实验指导书
1实现一个RPC应用程序㈠验内容创建一个简单的客户机——服务器的分布式应用程序,实现客户应用程序在一个远程过程调用中,向服务器传递一个整数,经过服务器端求阶乘后,将最终结果从客户机端输出。㈡处理流程2.1开发接口,具体步骤包括:2.1.1创建接口模板在命令行方式下运行uuidgen工具,生成文件Rpctest.idlD:\ProgramFiles\MicrosoftVisualStudio\Common\Toolsuuidgen/I/oRpctest.idlSolark:uuidgen/I/oRpctest.idl书写要注意uuidgen空格/I空格/oRpctest.idl其中参数o和Rpctest.idl中间没有空格。执行后,Rpctest.idl中内容为:[uuid(698cb6d9-df44-41a7-a66f-addc7e731fe1),version(1.0),]interfaceINTERFACENAME{}2.1.2替换Rpctest.idl中接口的定义(原来是:interfaceINTERFACENAME),改为:interfaceRpctest{//远程过程调用的求阶乘函数longRpcFactorial([in]longnVal);//出现[]的部分表示属性voidShutdown(void);//终止服务器程序函数Shutdown必须要2}2.1.3使用文本编辑器编写ACF(属性配置文件),Rpctest.acf[implicit_handle(handle_tRpctest_IfHandle)//这个必须要,用来连接服务器和客户端的]interfaceRpctest//solark:要和idl中接口名称一致{}2.1.4使用MIDL编译器进行编译(注:Rpctest.idl和Rpctest.acf都放Bin目录下)在命令行方式下运行MIDL.EXE,D:\ProgramFiles\MicrosoftVisualStudio\VC98\BinmidlRpctest.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.1VC环境下建一个空工程(win32consoleapplication)Rpctestserver,把Rpctest.h、Rpctest.idl、Rpctest.acf和Rpctest_s.c放到这个项目下面,然后导入Rpctest.hRpctest_s.c另外两个不导入也可以的创建memstub.h(内存管理函数,memstub.h内容固定,除头文件外无需改变)2.2.2实现具体的接口函数功能新建文件Rpctest_s_f.c中实现阶乘函数;同时Rpctest_s_f.c中也包括了终止服务器程序函数Shutdown32.2.3编写服务器源程序Rpctest_s.c一点都不改变。添加一个新文件main.cpp里面放main()函数.main()函数里代码负责建立RPC接口的捆绑,并用名称服务程序来注册它们及侦听RPC请求.Server端也与RPCruntime连接.2.2.4在VC环境下编译和链接服务器端程序,最终生成Rpctestserver.exe文件(在Debug文件里面)注:在VC中Project-Settings-Link中添加两个RPC运行库:rpcrt4.lib和rpcns4.lib编译工程生成Rpctestserver.exe,更名为server.exe(rpcns4.lib名字服务函数;rpcrt4.lib32位Windows运行期函数)3.开发客户机程序,具体步骤包括:2.3.1VC环境下建一个空项目Rpctestclient,把Rpctest.h、Rpctest.idl、Rpctest.acf和Rpctest_c.c放到这个项目下面,然后导入Rpctest.hRpctest_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客户端存根4Rpctest_s.c服务器端存根main_c.cpp客户端主程序main.cpp服务器端主程序Rpctest_s_f.c接口函数具体实现㈣运行结果1.执行过程1)首先运行server.exe。2)而后,在client.exe所在的目录下用命令行client.exe-ip192.168.1.146来启动客户端程序并与服务器端相连。3)在client窗口内输入exit或quit,server窗口关闭。特别要注意的是:由于客户端的程序中有:for(i=1;iargc;i++){if(strcmp(argv[i],-ip)==0){pszNetworkAddr=(unsignedchar*)argv[++i];break;}}/*此处的原理就是当用户执行client.exe-ip192.168.1.146,pszNetworkAddr为192.168.1.146此处192.168.1.146为服务器的IP号。在工程里编译运行程序,将不会执行这段语句argc,argv无数据,就无法连接服务器必须要在控制台输入:在工程里编译运行程序-开始-运行-输入cmd-改变路径到你client.exe文件所在的地方(如工程目录下debug文件夹下)注意:如果服务器端和客户端在同一台电脑上,此语句可以不执行。即工程里编译运行程序也可以出结果。*/此处的client.exe就是RpcTestclient.exe我把上面代码改为:cout请输入服务器IP地址endl;cinpszNetworkAddr;服务器端和客户端在同一台电脑上输入IP127.0.0.1是对的,有空试试分布的情况。实验结果:服务器端和客户端在同一台电脑上2.运行服务器端,结果如图(1)5图(1)3.运行客户端,结果如图(2)在工程里编译运行程序,所以没有出现要我输入服务端的IP地址。图(2)3.客户端运行后,服务器端变为:(如图3)6图(3)㈥实验结果分析服务器端运行后,一直处于监听状态,等待客户端请求。运行客户端后,客户端通过远程调用RpcFactorial()函数,将变量i的值传递给服务器,服务器的远程处理函数将其求阶乘后输出
本文标题:RPC分布式实验指导书
链接地址:https://www.777doc.com/doc-2848621 .html