XML-RPC
XML-RPC也是一种和RMI类似的远程调用的协议,它和RMI的不同之处在于它以标准的xml格式来定义请求的信息(请求的对象、方法、参数等),这样的好处是什么呢,就是在跨语言通讯的时候也可以使用。
来看下XML-RPC协议的一次远程通信过程:
- 客户端发起请求,按照XML-RPC协议将请求信息进行填充;
- 填充完毕后将xml转化为流,通过传输协议进行传输;
- 接收到在接收到流后转换为xml,按照XML-RPC协议获取请求的信息并进行处理;
- 处理完毕后将结果按照XML-RPC协议写入xml中并返回。
同样来回答问题:
- 传输的标准格式是?
标准格式的XML。
- 怎么样将请求转化为传输的流?
将XML转化为流。
- 怎么接收和处理流?
通过监听的端口获取到请求的流,转化为XML,并根据协议获取请求的信息,进行处理并将结果写入XML中返回。
- 传输协议是?
Http。
Binary-RPC
Binary-RPC看名字就知道和XML-RPC是差不多的了,不同之处仅在于传输的标准格式由XML转为了二进制的格式。
同样来回答问题:
- 传输的标准格式是?
标准格式的二进制文件。
- 怎么样将请求转化为传输的流?
将二进制格式文件转化为流。
- 怎么接收和处理流?
通过监听的端口获取到请求的流,转化为二进制文件,根据协议获取请求的信息,进行处理并将结果写入XML中返回。
- 传输协议是?
Http。
SOAP
SOAP原意为Simple Object Access Protocol,是一个用于分布式环境的、轻量级的、基于XML进行信息交换的通信协议,可以认为SOAP是XML RPC的高级版,两者的原理完全相同,都是http+XML,不同的仅在于两者定义的XML规范不同,SOAP也是Webservice采用的服务调用协议标准,因此在此就不多加阐述了。
CORBA
Common Object Request Broker Architecture(公用对象请求代理[调度]程序体系结构),是一组用来定义“分布式对象系统”的标准,由OMG(Object Menagement Group)作为发起和标准制定单位。CORBA的目的是定义一套协议,符合这个协议的对象可以互相交互,不论它们是用什么样的语言写的,不论它们运行于什么样的机器和操作系统。 CORBA在我看来是个类似于SOA的体系架构,涵盖可选的远程通信协议,但其本身不能列入通信协议这里来讲,而且CORBA基本淘汰,再加上对CORBA也不怎么懂,在此就不进行阐述了。
JMS
JMS呢,是实现java领域远程通信的一种手段和方法,基于JMS实现远程通信时和RPC是不同的,虽然可以做到RPC的效果,但因为不是从协议级别定义的,因此我们不认为JMS是个RPC协议,但它确实是个远程通信协议,在其他的语言体系中也存在着类似JMS的东西,可以统一的将这类机制称为消息机制,而消息机制呢,通常是高并发、分布式领域推荐的一种通信机制,这里的主要一个问题是容错(详细见ErLang论文)。
来看JMS中的一次远程通信的过程:
- 客户端将请求转化为符合JMS规定的Message;
- 通过JMS API将Message放入JMS Queue或Topic中;
- 如为JMS Queue,则发送中相应的目标Queue中,如为Topic,则发送给订阅了此Topic的JMS Queue。
- 处理端则通过轮训JMS Queue,来获取消息,接收到消息后根据JMS协议来解析Message并处理。
回答问题:
- 传输的标准格式是?
JMS规定的Message。
- 怎么样将请求转化为传输的流?
将参数信息放入Message中即可。
- 怎么接收和处理流?
轮训JMS Queue来接收Message,接收到后进行处理,处理完毕后仍然是以Message的方式放入Queue中发送或Multicast。
- 传输协议是?
不限。
基于JMS也是常用的实现远程异步调用的方法之一。
出处:CSDN
责任编辑:bluehearts
上一页 Java远程通讯可选技术及原理 [1] 下一页 Java远程通讯可选技术及原理 [3]
◎进入论坛网络编程版块参加讨论
|