加入收藏 | 设为首页 | 会员中心 | 我要投稿 湖南网 (https://www.hunanwang.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 建站 > 正文

6种微处事RPC框架,你知道几个?

发布时间:2019-08-21 20:56:37 所属栏目:建站 来源:佚名
导读:开源 RPC 框架有哪些呢? 一类是跟某种特定说话平台绑定的,另一类是与说话无关即跨说话平台的。 跟说话平台绑定的开源 RPC 框架首要有下面几种。 Dubbo:海内最早开源的 RPC 框架,由阿里巴巴公司开拓并于 2011 年尾对外开源,仅支持 Java 说话。 Motan:
副问题[/!--empirenews.page--]

开源 RPC 框架有哪些呢?

6种微处事RPC框架,你知道几个?

一类是跟某种特定说话平台绑定的,另一类是与说话无关即跨说话平台的。

跟说话平台绑定的开源 RPC 框架首要有下面几种。

  • Dubbo:海内最早开源的 RPC 框架,由阿里巴巴公司开拓并于 2011 年尾对外开源,仅支持 Java 说话。
  • Motan:微博内部行使的 RPC 框架,于 2016 年对外开源,仅支持 Java 说话。
  • Tars:腾讯内部行使的 RPC 框架,于 2017 年对外开源,仅支持 C++ 说话。
  • Spring Cloud:海外 Pivotal 公司 2014 年对外开源的 RPC 框架,仅支持 Java 说话

而跨说话平台的开源 RPC 框架首要有以下几种。

  • gRPC:Google 于 2015 年对外开源的跨说话 RPC 框架,支持多种说话。
  • Thrift:最初是由 Facebook 开拓的内部体系跨说话的 RPC 框架,2007 年孝顺给了 Apache 基金,成为 Apache 开源项目之一,支持多种说话。

假如你的营业场景仅仅范围于一种说话的话,可以选择跟说话绑定的 RPC 框架中的一种;

假如涉及多个说话平台之间的彼此挪用,就应该选择跨说话平台的 RPC 框架。

RPC 框架,它们详细有何区别?

1. Dubbo

先来聊聊 Dubbo,Dubbo 可以说是海内开源最早的 RPC 框架了,今朝只支持 Java 说话,它的架构可以用下面这张图展示。

6种微处事RPC框架,你知道几个?

从图中你能看到,Dubbo 的架构首要包括四个脚色,个中 Consumer 是处事斲丧者,Provider 是处事提供者,Registry 是注册中心,Monitor 是监控体系。

详细的交互流程是 Consumer 一端通过注册中心获取到 Provider 节点后,通过 Dubbo 的客户端 SDK 与 Provider 成立毗连,并提倡挪用。Provider 一端通过 Dubbo 的处事端 SDK 吸取到 Consumer 的哀求,处理赏罚后再把功效返回给 Consumer。

2. Motan

Motan 是海内其它一个较量著名的开源的 RPC 框架,同样也只支持 Java 说话实现,它的架构可以用下面这张图描写。

6种微处事RPC框架,你知道几个?

Motan 与 Dubbo 的架构相同,都必要在 Client 端(处事斲丧者)和 Server 端(处事提供者)引入 SDK,个中 Motan 框架首要包括下面几个成果模块。

register:用来和注册中心交互,包罗注册处事、订阅处事、处事改观关照、处事心跳发送等成果。

protocol:用来举办 RPC 处事的描写和 RPC 处事的设置打点,这一层还可以添加差异成果的 filter 用来完成统计、并发限定等成果。

serialize:将 RPC 哀求中的参数、功效等工具举办序列化与反序列化

transport:用来举办长途通讯,默认行使 Netty NIO 的 TCP 长链接方法。

cluster:哀求时会按照差异的高可用与负载平衡计策选择一个可用的 Server 提倡长途挪用。

3. Tars

Tars 是腾讯按照内部多年行使微处事架构的实践,总结而成的开源项目,仅支持 C++ 说话,它的架构图如下。

6种微处事RPC框架,你知道几个?

Tars 的架构交互首要包罗以下几个流程:

处事宣布流程:在 web 体系上传 server 的宣布包到 patch,上传乐成后,在 web 上提交宣布 server 哀求,由 registry 处事转到达 node,然后 node 拉取 server 的宣布包到当地,拉起 server 处事。

打点呼吁流程:web 体系上的可以提交打点 server 处事呼吁哀求,由 registry 处事转到达 node 处事,然后由 node 向 server 发送打点呼吁。

心跳上报流程:server 处事运行后,会按期上报心跳到 node,node 然后把处事心跳信息上报到 registry 处事,由 registry 举办同一打点。

信息上报流程:server 处事运行后,会按期上报统计信息到 stat,打印长途日记到 log,按期上报属性信息到 prop、上报非常信息到 notify、从 config 拉取处事设置信息。

client 会见 server 流程:client 可以通过 server 的工签字 Obj 间接会见 server,client 会从 registry 上拉取 server 的路由信息(如 IP、Port 信息),然后按照详细的营业特征(同步可能异步,TCP 可能 UDP 方法)会见 server(虽然 client 也可以通过 IP/Port 直接会见 server)。

4. Spring Cloud

Spring Cloud 操作 Spring Boot 特征整合了开源行业中优越的组件,整体对外提供了一套在微处事架构中处事管理的办理方案。

只支持 Java 说话平台,它的架构图可以用下面这张图来描写。

6种微处事RPC框架,你知道几个?

由此可见,Spring Cloud 微处事架构是由多个组件一路构成的,各个组件的交互流程如下。

哀求同一通过 API 网关 Zuul 来会见内部处事,先颠末 Token 举办安详认证。

通过安详认证后,网关 Zuul 从注册中心 Eureka 获取可用处事节点列表。

从可用处事节点中选取一个可用节点,然后把哀求分发到这个节点。

整个哀求进程中,Hystrix 组件认真处理赏罚处事超时熔断,Turbine 组件认真监控处事间的挪用和熔断相干指标,Sleuth 组件认真挪用链监控,ELK 认真日记说明。

5. gRPC

先来看下 gRPC,它的道理是通过 IDL(Interface Definition Language)文件界说处事接口的参数和返回值范例,然后通过代码天生措施天生处事端和客户端的详细实当代码,这样在 gRPC 里,客户端应用可以像挪用当地工具一样挪用另一台处事器上对应的要领。

6种微处事RPC框架,你知道几个?

它的首要特征包罗三个方面。

通讯协议回收了 HTTP/2,由于 HTTP/2 提供了毗连复用、双向流、处事器推送、哀求优先级、首部压缩等机制

IDL 行使了ProtoBuf,ProtoBuf 是由 Google 开拓的一种数据序列化协议,它的压缩和传输服从极高,语法也简朴

多说话支持,可以或许基于多种说话自动天生对应说话的客户端和处事端的代码。

6. Thrift

(编辑:湖南网)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

热点阅读