远程通信技术(RPC)概览

广义的远程通讯技术包括:RPC,WebService,RMI,JMS,EJB,JNDI

一、概念解释

  • RPC:远程过程调用,广义的RPC和与MQ并列属于系统间的交互方式,跨平台,通过http通信,通信的过程相当于http远程传送参数(串行化技术),本质上是一个请求相应模型。特征为隐藏底层通信细节,不需要直接处理Socket通讯和Http通信

    • rpc的实现:理论上来说WebService,gRPC,dubbo,微博Motan,thrift都是广义RPC技术的实现。
  • CORBA:面向对象的编程体系规范,分布式系统,跨语言,对标RMI(竞争关系)。

    • CORBA的实现:omniORB,TAO。
  • SOAP:简单对象访问协议,微软联合厂商对xml-rpc标准化,soap协议就是联合标准化的结果,而且微软抢先完善了soap协议,推出了webservice。对象访问协议指的是使用XML描述web service的信息(URI/类/参数/返回值),理论上SOAP就是一段xml

  • WebService:属于广义rpc的一种(常见的广义rpc实现还有xml-rpc和json-rpc),支持异构系统间的交互, 支持不同语言的通信,使用http通信,通过serlvet提供XML格式的数据,是SOAP协议的封装,WSDL是它的描述方式。

    • 基于SOAP实现WebService:引入JAX-WS规范(java实现soap的一个规范,为了简化基于soap的java开发,使用jax-ws可以让开发者不编写任何生产和处理soap的代码,jax-ws运行时会将api的调用转换为soap的消息)基于jax-ws的开发框架有ApacheAxis2和ApacheCXF(结合spring,是常用框架)
    • 基于REST的实现WebService:对应有JAX-RS规范,基于jax-rs的框架有ApacheWink,Jersey,Spring REST
  • WSDL:webservice描述语言,描述SOAP协议的,也是段XML

  • RMI:远程调用对象,其实是java实现了RPC的一组接口

    • 实现:没有框架,本身就是这种技术的实现
  • JMS:MQ

  • EJB:大型分布式,rmi-iiop协议

    • 直接对标spring体系:因为EJB是官方指定的标准,各个容器厂商都会不予余力的开发新版本来支持EJB标准,因此符合EJB的规范的容器,一般能适应企业的方方面面,而开源的spring结构体系就是个不统一的标准,你不能将spring+structs的架构迁移到spring+WebWork,更不能轻易将Spring+hibernate迁移到Spring+iBatis,但是因为EJB的标准问题,可以在WebSphere,WebLogic和JBOSS之间切换。因为EJB的过于重量级和难以使用,相当于民间开发了一套技术(spring)来覆盖了官方的EJB所提供的技术。

二、广义RPC发展历程

  • 广义RPC的技术发展历程
    以下按照时间顺序排序
    • CORBA
    • DCOM,COM+
    • JAVA RMI
    • .net remoting
    • XML-RPC,SOAP,WebService(冗余数据多,处理速度慢)
    • Hessian(二进制,官方只提供了java的实现)
    • JSON-RPC(没有统一实现)
    • Microsoft WCF,WebAPI(微软技术整合)
    • ZeroC Ice,Thrift,GRPC

下图为技术发展简图:

《远程通信技术(RPC)概览》 下载.png

三、狭义RPC技术框架

由于目前跨内存调用的普遍性,RPC往往代称更加具体的基于底层协议二进制流的RPC框架,与WebService最大的不同就是: 狭义的RPC基于二进制流的序列化和反序列化,故不能够提供跨语言的服务,但是比基于文本解析的WebService更加高效。

狭义RPC框架一般需要高性能的网络框架,如Netty,Mina,高性能的序列化反序列化框架,寻址方式,如果是带会话的RPC,还要有会话和状态保持功能。

当下XML-RPC,SOAP,WebService技术的缺陷:

  • 冗余数据太多,处理速度太慢。
  • RPC 风格的 Web Service 跨语言性不佳,而 Document 风格的 Web Service 又太过难用。
  • Web Service 没有解决用户的真正问题,只是把一个问题变成了另一个问题。
  • Web Service 的规范太过复杂,以至于在 .NET 和 Java 平台以外没有真正好用的实现,甚至没有可用的实现。
  • 跨语言跨平台只是 Web Service 的一个口号,虽然很多人迷信这一点,但事实上它并没有真正实现。
    原文作者:飞来来
    原文地址: https://www.jianshu.com/p/5cb25b06fdd3
    本文转自网络文章,转载此文章仅为分享知识,如有侵权,请联系博主进行删除。
点赞