您当前的位置:首页 > 电脑百科 > 程序开发 > 框架

聊聊从RPC到服务治理框架

时间:2020-08-12 15:31:11  来源:  作者:

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

聊聊从RPC到服务治理框架

 

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

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

聊聊从RPC到服务治理框架

 

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

聊聊从RPC到服务治理框架

 

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

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

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

聊聊从RPC到服务治理框架

 

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

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

聊聊从RPC到服务治理框架

 

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

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



Tags:服务治理框架   点击:()  评论:()
声明:本站部分内容及图片来自互联网,转载是出于传递更多信息之目的,内容观点仅代表作者本人,如有任何标注错误或版权侵犯请与我们联系(Email:2595517585@qq.com),我们将及时更正、删除,谢谢。
▌相关推荐
与一般的HTTP REST框架不同,一个可用的RPC架构不仅解决了远程调用问题,也提供了用于服务注册和服务发现的基础设施,比如RMI(Java语言的RPC)里的RMI Registry,如下图所示。 在使用R...【详细内容】
2020-08-12  Tags: 服务治理框架  点击:(54)  评论:(0)  加入收藏
▌简易百科推荐
近日只是为了想尽办法为 Flask 实现 Swagger UI 文档功能,基本上要让 Flask 配合 Flasgger, 所以写了篇 Flask 应用集成 Swagger UI 。然而不断的 Google 过程中偶然间发现了...【详细内容】
2021-12-23  Python阿杰    Tags:FastAPI   点击:(6)  评论:(0)  加入收藏
文章目录1、Quartz1.1 引入依赖<dependency> <groupId>org.quartz-scheduler</groupId> <artifactId>quartz</artifactId> <version>2.3.2</version></dependency>...【详细内容】
2021-12-22  java老人头    Tags:框架   点击:(11)  评论:(0)  加入收藏
今天来梳理下 Spring 的整体脉络啦,为后面的文章做个铺垫~后面几篇文章应该会讲讲这些内容啦 Spring AOP 插件 (了好久都忘了 ) 分享下 4ye 在项目中利用 AOP + MybatisPlus 对...【详细内容】
2021-12-07  Java4ye    Tags:Spring   点击:(14)  评论:(0)  加入收藏
&emsp;前面通过入门案例介绍,我们发现在SpringSecurity中如果我们没有使用自定义的登录界面,那么SpringSecurity会给我们提供一个系统登录界面。但真实项目中我们一般都会使用...【详细内容】
2021-12-06  波哥带你学Java    Tags:SpringSecurity   点击:(18)  评论:(0)  加入收藏
React 简介 React 基本使用<div id="test"></div><script type="text/javascript" src="../js/react.development.js"></script><script type="text/javascript" src="../js...【详细内容】
2021-11-30  清闲的帆船先生    Tags:框架   点击:(19)  评论:(0)  加入收藏
流水线(Pipeline)是把一个重复的过程分解为若干个子过程,使每个子过程与其他子过程并行进行的技术。本文主要介绍了诞生于云原生时代的流水线框架 Argo。 什么是流水线?在计算机...【详细内容】
2021-11-30  叼着猫的鱼    Tags:框架   点击:(21)  评论:(0)  加入收藏
TKinterThinter 是标准的python包,你可以在linx,macos,windows上使用它,你不需要安装它,因为它是python自带的扩展包。 它采用TCL的控制接口,你可以非常方便地写出图形界面,如...【详细内容】
2021-11-30    梦回故里归来  Tags:框架   点击:(26)  评论:(0)  加入收藏
前言项目中的配置文件会有密码的存在,例如数据库的密码、邮箱的密码、FTP的密码等。配置的密码以明文的方式暴露,并不是一种安全的方式,特别是大型项目的生产环境中,因为配置文...【详细内容】
2021-11-17  充满元气的java爱好者  博客园  Tags:SpringBoot   点击:(25)  评论:(0)  加入收藏
一、搭建环境1、创建数据库表和表结构create table account(id INT identity(1,1) primary key,name varchar(20),[money] DECIMAL2、创建maven的工程SSM,在pom.xml文件引入...【详细内容】
2021-11-11  AT小白在线中  搜狐号  Tags:开发框架   点击:(29)  评论:(0)  加入收藏
SpringBoot开发的物联网通信平台系统项目功能模块 功能 说明 MQTT 1.SSL支持 2.集群化部署时暂不支持retain&will类型消 UDP ...【详细内容】
2021-11-05  小程序建站    Tags:SpringBoot   点击:(55)  评论:(0)  加入收藏
相关文章
    无相关信息
最新更新
栏目热门
栏目头条