RPC之java应用

 什么是RPC?Remote Procedure Call,远程过程调用。也就是说,调用过程代码并不是在调用者本地运行,而是要实现调用者与被调用者二地之间的连接与通信。比较严格的定义是:

   

Xml代码   收藏代码
  1. Remote procedure call (RPC) is a protocol that allows a computer program running on one computer to cause a subroutine on another computer to be executed without the programmer explicitly coding the details for this interaction. When the software in question is written using object-oriented principles, RPC may be referred to asremote invocation or remote method invocation.  

 

 

 这样一讲, 容易联想到C/S模式的程序设计,我想是对的。RPC的基本通信模型是基于Client/Server进程间相互通信模型的一种同步通信形式;它对 Client提供了远程服务的过程抽象,其底层消息传递操作对Client是透明的。在RPC中,Client即是请求服务的调用者(Caller),而 Server则是执行Client的请求而被调用的程序 (Callee)。下图是RPC调用协议图:



 

    首先是建立RPC服务,约定底层的RPC传输通道(UDP或是TCP)。客户端的调用参数根据传输前所提供的目的地址及RPC 上层应用程序号,通过底层的RPC传输通道转至相应的服务器,即RPC Application Porgramme Server。客户端随即处于等待状态,以服务器等待应答或Time Out超时信号。当服务器端获得了请求消息,会根据注册RPC时告诉RPC系统的程序入口地址执行相应的操作,并将结果返回至客户端。当一次RPC调用结束后,相应线程发送相应的信号,客户端程序便继续运行。

下载xml-rpc jar包 http://ws.apache.org/xmlrpc/download.html 当前版本:3.1.3



 

1、业务处理接口

 

Java代码   收藏代码
  1. public interface ServicesHandler {  
  2.     public String execute(String str);  
  3. }  

 

 

2、业务接口实现

 

Java代码   收藏代码
  1. public class HelloHandler implements ServicesHandler {  
  2.     public String execute(String str) {          
  3.         return "hello "+str+"!";  
  4.     }  
  5. }  

 

 

3、客户端

 

Java代码   收藏代码
  1. import java.net.MalformedURLException;  
  2. import java.net.URL;  
  3. import java.util.Vector;  
  4.   
  5. import org.apache.xmlrpc.XmlRpcException;  
  6. import org.apache.xmlrpc.client.XmlRpcClient;  
  7. import org.apache.xmlrpc.client.XmlRpcClientConfigImpl;  
  8.   
  9. public class TestClient {  
  10.   
  11.     /** 
  12.      * @param args 
  13.      */  
  14.     public static void main(String[] args) {  
  15.         try {  
  16.             //配置客户端  
  17.             XmlRpcClientConfigImpl config = new XmlRpcClientConfigImpl();  
  18.             //设置服务器端地址  
  19.             config.setServerURL(new URL("http://localhost:8080/Rpc/HelloHandler"));  
  20.             //创建XmlRpc客户端  
  21.             XmlRpcClient client = new XmlRpcClient();  
  22.             //绑定以上设置  
  23.             client.setConfig(config);  
  24.             //创建参数列表  
  25.             Vector<String> params = new Vector<String>();  
  26.             params.addElement("flyoung");  
  27.             //执行XML-RPC 请求  
  28.             String result =(String) client.execute("HelloHandler.execute", params);  
  29.             System.out.println("result:"+result);  
  30.            } catch (MalformedURLException e) {  
  31.             e.printStackTrace();  
  32.             } catch (XmlRpcException e) {  
  33.             e.printStackTrace();  
  34.         }  
  35.     }  
  36. }  

 

 

4、服务器端

 

Java代码   收藏代码
  1. import java.io.IOException;  
  2.   
  3. import javax.servlet.ServletConfig;  
  4. import javax.servlet.ServletException;  
  5. import javax.servlet.http.HttpServlet;  
  6. import javax.servlet.http.HttpServletRequest;  
  7. import javax.servlet.http.HttpServletResponse;  
  8.   
  9. import org.apache.xmlrpc.XmlRpcException;  
  10. import org.apache.xmlrpc.server.PropertyHandlerMapping;  
  11. import org.apache.xmlrpc.server.XmlRpcServerConfigImpl;  
  12. import org.apache.xmlrpc.webserver.XmlRpcServletServer;  
  13. import com.flyoung.xmlrpc.HelloHandler;  
  14.   
  15. public class XmlRpcServicesServlet extends HttpServlet {  
  16.     private XmlRpcServletServer server;  
  17.   
  18.     @Override  
  19.     public void init(ServletConfig config) throws ServletException {  
  20.         super.init(config);  
  21.         try {  
  22.             //创建XmlRpcServletServer对象  
  23.             server = new XmlRpcServletServer();  
  24.               
  25.             //set up handler mapping of XmlRpcServletServer object  
  26.             PropertyHandlerMapping pmp = new PropertyHandlerMapping();  
  27.             pmp.addHandler("HelloHandler", HelloHandler.class);  
  28.             server.setHandlerMapping(pmp);  
  29.               
  30.             //more config of XmlRpcServletServer object  
  31.             XmlRpcServerConfigImpl serverConfig = (XmlRpcServerConfigImpl)server.getConfig();  
  32.             serverConfig.setEnabledForExtensions(true);  
  33.             serverConfig.setContentLengthOptional(false);  
  34.         } catch (XmlRpcException e) {  
  35.             // TODO Auto-generated catch block  
  36.             e.printStackTrace();  
  37.         }  
  38.     }  
  39.       
  40.       
  41.     @Override  
  42.     protected void doGet(HttpServletRequest req, HttpServletResponse resp)  
  43.             throws ServletException, IOException {  
  44.           
  45.         server.execute(req, resp);  
  46.     }  
  47.   
  48.     @Override  
  49.     protected void doPost(HttpServletRequest req, HttpServletResponse resp)  
  50.             throws ServletException, IOException {  
  51.           
  52.         server.execute(req, resp);  
  53.     }      
  54.       
  55. }  

 

 

5、xml配置

 

Java代码   收藏代码
  1. <?xml version="1.0" encoding="UTF-8"?>  
  2. <web-app version="2.5"   
  3.     xmlns="http://java.sun.com/xml/ns/javaee"   
  4.     xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"   
  5.     xsi:schemaLocation="http://java.sun.com/xml/ns/javaee   
  6.     http://java.sun.com/xml/ns/javaee/web-app_2_5.xsd">  
  7.   <display-name></display-name>      
  8.   <welcome-file-list>  
  9.     <welcome-file>index.jsp</welcome-file>  
  10.   </welcome-file-list>  
  11.   <servlet>  
  12.       <servlet-name>XmlRpcServer</servlet-name>  
  13.       <servlet-class>com.flyoung.xmlrpc.XmlRpcServicesServlet</servlet-class>  
  14.   </servlet>  
  15.   <servlet-mapping>  
  16.      <servlet-name>XmlRpcServer</servlet-name>  
  17.       <url-pattern>/HelloHandler</url-pattern>  
  18.   </servlet-mapping>  
  19. </web-app>  

 

 

6、测试结果

Java代码   收藏代码
  1. result:hello flyoung!  

 

    在RPC中,当一个请求到达RPC服务器时,这个请求就包含了一个参数集和一个文本值,通常形成“classname.methodname”的形 式。这就向RPC服务器表明,被请求的方法在为“classname”的类中,名叫“methodname”。然后RPC服务器就去搜索与之相匹配的类和 方法,并把它作为那种方法参数类型的输入。这里的参数类型是与RPC请求中的类型是匹配的。一旦匹配成功,这个方法就被调用了,其结果被编码后返回客户 方。

 

缺点:

  1)XML-RPC的消息系统过于简单,没有完整意义上的消息模型;
  2)XML-RPC调用服务的方式要求直接指定对象和方法,称不上完整的面向服务的体系;
  3)XML-RPC服务器端提供的服务实际上是特定对象的某个方法,限制了服务器端的开发。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值