RPC使用C/S方式,采用http协议,发送请求到服务器,等待服务器返回结果。这个请求包括一个参数集和一个文本集,一般造成“classname.methodname”形式。优势是跨语言跨平台,C端、S端有更大的独立性,缺点是不支持对象,没法在编译器检查错误,只能在运行期检查。java
Web Service提供的服务是基于web容器的,底层使用http协议,相似一个远程的服务提供者,好比天气预报服务,对各地客户端提供天气预报,是一种请求应答的机制,是跨系统跨平台的。就是经过一个servlet,提供服务出去。web
首先客户端从服务器的到WebService的WSDL,同时在客户端声称一个代理类(Proxy Class) 这个代理类负责与WebService服务器进行Request 和Response。当一个数据(XML格式的)被封装成SOAP格式的数据流发送到服务器端的时候,就会生成一个进程对象,而且把接收到这个Request的SOAP包进行解析,而后对事物进行处理,处理结束之后再对这个计算结果进行SOAP包装,而后把这个包做为一个Response发送给客户端的代理类(Proxy Class),一样地,这个代理类也对这个SOAP包进行解析处理,继而进行后续操做。这就是WebService的一个运行过程。服务器
Web Service大致上分为5个层次:
1. Http传输信道
2. XML的数据格式
3. SOAP封装格式
4. WSDL的描述方式
5. UDDI UDDI是一种目录服务,企业可使用它对Webservices进行注册和搜索网络
RMI 采用stubs 和 skeletons 来进行远程对象(remote object)的通信。stub 充当远程对象的客户端代理,有着和远程对象相同的远程接口,远程对象的调用实际是经过调用该对象的客户端代理对象stub来完成的,经过该机制RMI就比如它是本地工做,采用tcp/ip协议,客户端直接调用服务端上的一些方法。优势是强类型,编译期可检查错误,缺点是只能基于Java语言,客户机与服务器紧耦合。架构
JMS是Java的消息服务,JMS的客户端之间能够经过JMS服务进行异步的消息传输。JMS支持两种消息模型:Point-to-Point(P2P)和Publish/Subscribe(Pub/Sub),即点对点和发布订阅模型。异步
(1)RPC 跨语言,而 RMI只支持Java。
(2)RMI 调用远程对象方法,容许方法返回 Java 对象以及基本数据类型,而RPC 不支持对象的概念,传送到 RPC 服务的消息由外部数据表示 (External Data Representation, XDR) 语言表示,这种语言抽象了字节序类和数据类型结构之间的差别。只有由 XDR 定义的数据类型才能被传递, 能够说 RMI 是面向对象方式的 Java RPC 。
(3)在方法调用上,RMI中,远程接口使每一个远程方法都具备方法签名。若是一个方法在服务器上执行,可是没有相匹配的签名被添加到这个远程接口上,那么这个新方法就不能被RMI客户方所调用。
在RPC中,当一个请求到达RPC服务器时,这个请求就包含了一个参数集和一个文本值,一般造成“classname.methodname”的形式。这就向RPC服务器代表,被请求的方法在为 “classname”的类中,名叫“methodname”。而后RPC服务器就去搜索与之相匹配的类和方法,并把它做为那种方法参数类型的输入。这里的参数类型是与RPC请求中的类型是匹配的。一旦匹配成功,这个方法就被调用了,其结果被编码后返回客户方。tcp
采用JMS 服务,对象是在物理上被异步从网络的某个JVM 上直接移动到另外一个JVM 上(是消息通知机制)
而RMI 对象是绑定在本地JVM 中,只有函数参数和返回值是经过网络传送的(是请求应答机制)。分布式
RMI通常都是同步的,也就是说,当client调用Server的一个方法的时候,须要等到对方的返回,才能继续执行client端,这个过程调用本地方法感受上是同样的,这也是RMI的一个特色。
JMS 通常只是一个点发出一个Message到Message Server,发出以后通常不会关心谁用了这个message。
因此,通常RMI的应用是紧耦合,JMS的应用相对来讲是松散耦合应用。ide
RMI是在tcp协议上传递可序列化的java对象,只能用在java虚拟机上,绑定语言,客户端和服务端都必须是java
webservice没有这个限制,webservice是在http协议上传递xml文本文件,与语言和平台无关函数
Webservice专一于远程服务调用,jms专一于信息交换。
大多数状况下Webservice是两系统间的直接交互(Consumer <--> Producer),而大多数状况下jms是三方系统交互(Consumer <- Broker -> Producer)。固然,JMS也能够实现request-response模式的通讯,只要Consumer或Producer其中一方兼任broker便可。
JMS能够作到异步调用彻底隔离了客户端和服务提供者,可以抵御流量洪峰; WebService服务一般为同步调用,须要有复杂的对象转换,相比SOAP,如今JSON,rest都是很好的http架构方案;(举一个例子,电子商务的分布式系统中,有支付系统和业务系统,支付系统负责用户付款,在用户在银行付款后须要通知各个业务系统,那么这个时候,既能够用同步也能够用异步,使用异步的好处就能抵御网站暂时的流量高峰,或者能应对慢消费者。)
JMS是java平台上的消息规范。通常jms消息不是一个xml,而是一个java对象,很明显,jms没考虑异构系统,说白了,JMS就没考虑非java的东西。可是好在如今大多数的jms provider(就是JMS的各类实现产品)都解决了异构问题。相比WebService的跨平台各有千秋吧。