与一般的HTTP REST框架不同,一个可用的RPC架构不仅解决了远程调用问题,也提供了用于服务注册和服务发现的基础设施,比如RMI(Java语言的RPC)里的RMI Registry,如下图所示。

在使用RMI时,我们所开发的“远程对象”(RemoteObject)都需要被注册(Binding)到Registry里,客户端(Client)则首先需要通过Registry的接口查询到远程对象的访问地址,然后才能发起对远程对象的“远程过程调用”,将这种模式表达为更抽象的模型,就是如下图所示的服务注册和服务发现的通用模型。

从RPC和COBRA发展而来的服务注册与服务发现模型,被后来者奉为经典。如下所示是ZeroC Ice的实现架构图,其中注册表实现了主从复制的特性,避免了单点故障。

服务注册与服务发现的模型在Web Service时代被提到了一个很高的境界,Web Service的核心架构一般如下图所示。

在Web Service的技术架构中,用XML定义的编程语言中立的服务接口描述语言WSDL其实来自COBRA中的IDL,基于Socket的复杂RPC调用被简单和容易掌握的HTTP上的SOAP调用所替换。

此外,为了应对不同开发商的“互联互不同”及“以自我为中心”的思想,IBM倡导了全球服务注册中心(UDDIRegistry)的理念,希望各个厂商都能将自己的Web Service注册到一起,全球联网,服务无国界,这次尝试以失败告终,无数公司不得不重复开发并不很复杂的软件系统。

后来出现了SOA这个新概念,虽然业界对SOA这个概念有各种“诠释”,但“面向服务的架构”即以服务(Service)为中心的分布式架构深入人心,如下图所示是一个理想化的大一统的SOA架构蓝图,我们看到服务注册与服务发布模型及RPC技术依然是SOA的技术核心。

服务注册与服务发布模型成为后来通用分布式系统架构的核心和关键技术基础,也被赋予一个新概念——服务治理框架。

服务治理框架这个概念与SOA在本质上属于一类,它的一个典型代表是曾经热门的开源项目——Dubbo。下面给出了Dubbo的原理概念图,可以看出,相对于SOA架构,在Dubbo的服务治理框架中最大的一个亮点是增加了服务监控这个必要的运维特性。

Dubbo同时提出了很多看起来比较吸引人的新特性,比如服务编排、服务降级、访问规则控制,但实际上这并不是核心。

作为一个分布式系统的重要基础设施,稳定、高性能的RPC通信及多语言支持才是其关键的核心指标。

webservice框架_聊聊从RPC到服务治理框架相关推荐

  1. 分布式服务治理框架Dubbo

    前言 Dubbo是一个被国内很多互联网公司广泛使用的开源分布式服务治理框架,是一个非常全面的SOA基础框架,当当网在Dubbo基础上新增了一些功能,并将其命名为Dubbox(Dubbo eXtensi ...

  2. 分布式服务治理框架Dubbo的前世今生及应用实战

    Dubbo的出现背景# Dubbo从开源到现在,已经出现了接近10年时间,在国内各大企业被广泛应用. 它到底有什么魔力值得大家去追捧呢?本篇文章给大家做一个详细的说明. 大规模服务化对于服务治理的要求 ...

  3. 美团分布式服务治理框架OCTO之一:服务治理

    写在前面 之前的文章介绍过美团的中间件leaf-code,今天介绍另一款非常强的中间件系统Octo,其实Octo算不上是中间件系统,应该是一整套分布式服务治理平台,美团的很多中间件能力都是通过Octo ...

  4. 新开两场构建服务治理框架的直播分享

    之前有问过群里同学们对学习服务治理的意向,大家都表示想听.但是备课是在太累,所以后面一直懒得弄. 昨天又有一位同学在群里@我,问什么时候讲服务治理呢.我想自己也不能偷懒了,之前承诺过的课,应该讲讲了, ...

  5. 可能是最详尽的证券服务治理框架思路 | 华泰证券企业服务化思考 | 中生代38期...

    1.开始之前,请先容许我介绍下华泰证券,华泰证券中全国领先的大型综合性证券集团,具有庞大的客户基础.领先的互联网平台及敏捷协同的全业务链体系,股票代码601688,主营业务主要有经纪及财富管理.投资银 ...

  6. 微服务治理框架(C++版)详细设计

    @TOC 微服务治理框架(C++版)详细设计 概述 gRPC 是一款高性能.开源的 RPC 框架,产自 Google,基于 ProtoBuf 序列化协议进行开发,支持多种语言(C++.Golang.P ...

  7. 微服务治理框架- - -Spring Cloud

     前言:最近微服务很是火热,那么什么是微服务?相信小伙伴们对此也是一知半解,那么今天叶秋学长带领大家一起学习微服务治理框架Spring Cloud,快来跟着学长一起学习吧~~ 目录 对SpringCl ...

  8. 美团分布式服务治理框架OCTO之二:Mesh化

    写在前面 前面的文章主要介绍了美团Octo服务治理框架,随着云原生的崛起,大量服务治理体系普遍"云原生"化,而Mesh则是云原生中非常重要的一个流派,今天我们看下美团的Octo是如 ...

  9. 自研服务治理框架----文章汇总

    2019独角兽企业重金招聘Python工程师标准>>> 自研服务治理框架----获取本机IP地址 自研服务治理框架----服务注册 自研服务治理框架----服务地址发现 自研服务治理 ...

最新文章

  1. java如何按照标签替换_Maven(五):resources、profiles标签的实践
  2. IP地址基础网络知识—Vecloud微云
  3. 详解C中volatile关键字
  4. 内网通 去广告 代码_一文秒懂Facebook广告投放常见专业术语
  5. MATLAB编辑GUI界面
  6. 管道popen和pclose的实例使用
  7. C语言课程设计火车订票系统存储结构设计,火车售票系统(数据结构课设)
  8. 替换过的mysql能找回来_MySQL 误操作后数据恢复(update,delete忘加where条件)
  9. JAVA设计模式---单例模式的几种实现方式比较
  10. 人体存在雷达传感器,毫米波雷达技术探测应用,智能感知静态人体存在
  11. 大一c语言实验调试步骤,大一c语言实验报告.docx
  12. kali linux 添加字体,在kali linux之下安装wps之后 报错字体缺失
  13. 2022 Google I/O 谷歌开发者大会汇总
  14. java 计时器归零_加一计时器——每隔1s六位数码管显示数字加1,直至999999,之后归零,重新开始。...
  15. 通过 blast 结果查看 测序数据fastq是否被污染,以及污染reads所属物种、所占比例
  16. 数据库之操作MySQL
  17. 国内图像处理相关期刊
  18. 解读AFNetworking4.0请求原理
  19. 01654报错: 索引无法通过8扩展
  20. 稳定性高可用测试——各大厂质量保障实践分享汇总(上)

热门文章

  1. 从(知乎大量的数据上保持毫秒级的查询响应时间)上看什么是 TiDB?
  2. Shell 脚本的时间的加减,以及时间差的计算
  3. map和mapValues的纠纷
  4. 数据库不推荐使用外键的9个理由
  5. Purpose of cmove instruction in x86 assembly? | cmove 指令如何避免错误的分支预测带来的开销?
  6. 安装Cocoapods详细教程
  7. css3盒模型:IE6混杂模式下的盒模型
  8. SQL 中 left join 的底层原理(各种JOIN的复杂度探究)
  9. 【简便解法】1091 N-自守数 (15分)
  10. 2.在某应用软件中需要记录业务方法的调用日志,在不修改现有业务类的基础上为每一个类提供一个日志记录代理类,在代理类中输出日志,例如在业务方法 method() 调用之前输出“方法 method() 被