什么是RPC?Remote Procedure Call,远程过程调用。也就是说,调用过程代码并不是在调用者本地运行,而是要实现调用者与被调用者二地之间的连接与通信。比较严格的定义是:
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、业务处理接口
public interface ServicesHandler { public String execute(String str); }
2、业务接口实现
public class HelloHandler implements ServicesHandler { public String execute(String str) { return "hello "+str+"!"; } }
3、客户端
import java.net.MalformedURLException; import java.net.URL; import java.util.Vector; import org.apache.xmlrpc.XmlRpcException; import org.apache.xmlrpc.client.XmlRpcClient; import org.apache.xmlrpc.client.XmlRpcClientConfigImpl; public class TestClient { /** * @param args */ public static void main(String[] args) { try { //配置客户端 XmlRpcClientConfigImpl config = new XmlRpcClientConfigImpl(); //设置服务器端地址 config.setServerURL(new URL("http://localhost:8080/Rpc/HelloHandler")); //创建XmlRpc客户端 XmlRpcClient client = new XmlRpcClient(); //绑定以上设置 client.setConfig(config); //创建参数列表 Vector<String> params = new Vector<String>(); params.addElement("flyoung"); //执行XML-RPC 请求 String result =(String) client.execute("HelloHandler.execute", params); System.out.println("result:"+result); } catch (MalformedURLException e) { e.printStackTrace(); } catch (XmlRpcException e) { e.printStackTrace(); } } }
4、服务器端
import java.io.IOException; import javax.servlet.ServletConfig; import javax.servlet.ServletException; import javax.servlet.http.HttpServlet; import javax.servlet.http.HttpServletRequest; import javax.servlet.http.HttpServletResponse; import org.apache.xmlrpc.XmlRpcException; import org.apache.xmlrpc.server.PropertyHandlerMapping; import org.apache.xmlrpc.server.XmlRpcServerConfigImpl; import org.apache.xmlrpc.webserver.XmlRpcServletServer; import com.flyoung.xmlrpc.HelloHandler; public class XmlRpcServicesServlet extends HttpServlet { private XmlRpcServletServer server; @Override public void init(ServletConfig config) throws ServletException { super.init(config); try { //创建XmlRpcServletServer对象 server = new XmlRpcServletServer(); //set up handler mapping of XmlRpcServletServer object PropertyHandlerMapping pmp = new PropertyHandlerMapping(); pmp.addHandler("HelloHandler", HelloHandler.class); server.setHandlerMapping(pmp); //more config of XmlRpcServletServer object XmlRpcServerConfigImpl serverConfig = (XmlRpcServerConfigImpl)server.getConfig(); serverConfig.setEnabledForExtensions(true); serverConfig.setContentLengthOptional(false); } catch (XmlRpcException e) { // TODO Auto-generated catch block e.printStackTrace(); } } @Override protected void doGet(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException { server.execute(req, resp); } @Override protected void doPost(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException { server.execute(req, resp); } }
5、xml配置
<?xml version="1.0" encoding="UTF-8"?> <web-app version="2.5" xmlns="http://java.sun.com/xml/ns/javaee" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://java.sun.com/xml/ns/javaee http://java.sun.com/xml/ns/javaee/web-app_2_5.xsd"> <display-name></display-name> <welcome-file-list> <welcome-file>index.jsp</welcome-file> </welcome-file-list> <servlet> <servlet-name>XmlRpcServer</servlet-name> <servlet-class>com.flyoung.xmlrpc.XmlRpcServicesServlet</servlet-class> </servlet> <servlet-mapping> <servlet-name>XmlRpcServer</servlet-name> <url-pattern>/HelloHandler</url-pattern> </servlet-mapping> </web-app>
6、测试结果
result:hello flyoung!
在RPC中,当一个请求到达RPC服务器时,这个请求就包含了一个参数集和一个文本值,通常形成“classname.methodname”的形 式。这就向RPC服务器表明,被请求的方法在为“classname”的类中,名叫“methodname”。然后RPC服务器就去搜索与之相匹配的类和 方法,并把它作为那种方法参数类型的输入。这里的参数类型是与RPC请求中的类型是匹配的。一旦匹配成功,这个方法就被调用了,其结果被编码后返回客户 方。
缺点:
1)XML-RPC的消息系统过于简单,没有完整意义上的消息模型;
2)XML-RPC调用服务的方式要求直接指定对象和方法,称不上完整的面向服务的体系;
3)XML-RPC服务器端提供的服务实际上是特定对象的某个方法,限制了服务器端的开发。
相关推荐
JSON-RPC-Java可运行在Servlet容器中如Tomcat也可以运行在JBoss与其它J2EE应用服务器中因此可以在一个基于JavaScript与DHTML的Web应用程序中利用它来直接调用普通Java方法与EJB方法。我们可以很方便的使用JSON-RPC-...
### 利用JSON-RPC-Java构建下一代Web应用程序 #### 概述 本文将探讨如何通过结合使用JSON-RPC-Java技术来构建高度动态、功能丰富的Web应用程序。JSON-RPC-Java是一种允许从JavaScript端透明地调用远程Java方法的...
* 企业应用程序:JSON-RPC for Java 可以应用于企业应用程序中,提供远程过程调用解决方案。 在了解 JSON-RPC for Java 的使用场景后,让我们来了解它的配置和使用方法。JSON-RPC for Java 的配置非常简单,只需要...
这个实现可能包含了服务器端和客户端的库,使得开发者能够利用JSON-RPC协议在Java应用之间进行通信。源代码的提供意味着用户可以查看并自定义其内部工作方式,以适应特定项目的需求。 描述中的"JSON-RPC for Java....
"Java RPC技术在Web应用服务器集群系统中的应用" Java RPC技术是指使用Java语言进行胖客户端的开发,取代传统的AWT、Swing等技术。RPC(Remote Procedure Call)是一种远程调用技术,允许不同的应用程序之间进行...
在实际应用中,JSON-RPC Java库通常会提供以下功能: 1. **服务定义**:定义服务接口,包括方法名、输入参数和返回类型。 2. **服务暴露**:将Java方法暴露为JSON-RPC服务,可以通过HTTP、WebSocket或其他协议进行...
在实际应用中,Java有多个成熟的RPC框架,如Apache Dubbo、Hessian、gRPC等。这些框架已经封装了上述过程,提供更加便捷、高效的RPC解决方案。 总结一下,Java RPC调用涉及服务接口定义、数据序列化、网络通信、...
Phprpc是一个跨语言的远程过程调用(RPC)框架,它允许PHP和Java应用程序之间进行无缝通信。在本实例中,我们将深入探讨如何在Java环境中设置和使用Phprpc服务器,以便理解其核心概念和操作流程。 1. **Phprpc简介*...
在Java环境中,JSON-RPC允许应用程序通过网络调用其他服务器上的方法,仿佛它们是本地对象一样。这种协议常用于构建分布式系统和服务之间的通信。 在Java中实现JSON-RPC,你需要了解以下关键概念: 1. **JSON**: ...
- **JSON-RPC-Java:**实现了JSON-RPC协议的Java库,允许Java应用程序作为服务端接收来自JavaScript客户端的请求,并返回相应的结果。 #### 透明调用远程Java方法 - **原理:**JSON-RPC-Java库提供了机制,使得...
继《JavaScript高级应用与实践》之后推出的json-rpc-for-java开源代码,是仅仅100行的javascript代码和不到10个java文件实现的超级轻量级的通过 javaScript快速调用java对象并返回任意对象的轻量级框架,并且支持...
JSON-RPC for Java适用于各种分布式系统,如微服务架构、Web服务、移动应用后端等。随着云计算和物联网的发展,轻量级的远程调用技术将会在更多的场景中发挥作用。 ### 术语 1. **JSON-RPC**:JSON Remote ...
通过阅读和理解"json-rpc-java-1.0"源代码,可以学习到如何在实际项目中有效地应用JSON-RPC。 总结来说,"json-rpc-java-1.0"项目提供了JSON-RPC协议的Java实现,涉及到JSON数据结构的使用、网络通信、序列化和反...
JSONRPC(JSON Remote Procedure Call)是一种轻量级的远程过程调用协议,它使用JSON(JavaScript Object Notation)作为数据...通过理解JSONRPC的工作原理和Java中的实现方式,你可以更轻松地在项目中应用这一技术。
### 自定义RPC的Java实现详解 #### 一、引言 在现代软件开发中,分布式系统变得越来越普遍,其中远程过程调用(RPC)技术因其简单高效的特点而在跨网络节点间进行服务通信方面发挥着重要作用。本文将详细介绍如何...
Phprpc结合Web服务,可能意味着它可以创建SOAP或RESTful风格的Web服务接口,使得Java应用可以作为Web服务供其他系统调用,或者消费其他Web服务。 5. **文件结构**:"phprpc_3.0.2_java"可能包含以下组件: - `src`...
本压缩包“json-rpc-java-1.0.zip”包含了JSON-RPC在Java平台上的实现及相关使用示例。 首先,JSON-RPC的基本原理是,客户端通过HTTP请求将一个JSON格式的请求体发送到服务器,请求体包含了要调用的方法名和参数。...
本压缩包“java开发常用jar包之json-rpc.rar”包含了与JSON-RPC相关的Java库,便于开发者集成到他们的项目中。 一、JSON-RPC协议 1. JSON-RPC简介:JSON-RPC是一种基于JSON的RPC协议,它定义了如何通过HTTP或其他...