远程通信技术(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

下图为技术发展简图:


下载.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 的一个口号,虽然很多人迷信这一点,但事实上它并没有真正实现。
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 204,793评论 6 478
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 87,567评论 2 381
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 151,342评论 0 338
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,825评论 1 277
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,814评论 5 368
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,680评论 1 281
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 38,033评论 3 399
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,687评论 0 258
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 42,175评论 1 300
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,668评论 2 321
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,775评论 1 332
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,419评论 4 321
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 39,020评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,978评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,206评论 1 260
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 45,092评论 2 351
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,510评论 2 343

推荐阅读更多精彩内容

  • 在分布式服务框架中,一个最基础的问题就是远程服务是怎么通讯的,在Java领域中有很多可实现远程通讯的技术,例如:R...
    wyatt_plus阅读 814评论 0 4
  • Spring Cloud为开发人员提供了快速构建分布式系统中一些常见模式的工具(例如配置管理,服务发现,断路器,智...
    卡卡罗2017阅读 134,596评论 18 139
  • 岁月女孩----1 我叫林然,今年14岁。读初一,嘴巴有点毒舌,对别人的弱点总是逮住不放,会动脑筋,爱耍一些小聪明...
    耳谷阅读 199评论 0 0
  • MIAMI — The Heat’s current roster is made up of 19 player...
    prudenceli阅读 118评论 0 0
  • 而此时,任然却衣衫不整的走在人来人往的人行路上,她的头发看上去像一团杂草一样凌乱的披在肩上,全是褶皱的衬衫被胡...
    biubiubiu糖阅读 238评论 0 2