RMI是Sun公司定义的一个Java分布式框架,包括一些Java接口等;而RPC是一个网络协议.
JMS是java平台上的消息规范。一般JMS消息不是一个XML,而是一个Java对象。
JMS 与 RMI 的区别在于:
采用 JMS 服务,对象是在物理上被异步从网络的某个 JVM 上直接移动到另一个 JVM 上。
而 RMI 对象是绑定在本地 JVM 中,只有函数参数和返回值是通过网络传送的。
SOAP与JMS对比:
1)SOAP专注于远程服务调用,JMS专注于信息交换。
2)大多数情况下soap是两系统间的直接交互(Consumer <--> Producer),而大多数情况下JMS是三方系统交互(Consumer <- Broker -> Producer)。
当然,JMS也可以实现request-response模式的通信,只要Consumer或Producer其中一方兼任broker即可。
3)多数情况下,WS是同步的,JMS是异步。虽然,WS也可以是异步的,而JMS也可以是同步的。
rmi 不需要 类似 mq 的 server;
jms 支持异步,rmi 是最基础的通讯,没有异步之说。