导航菜单
首页 » 搭配TOP指南 » 正文

电饭锅做蛋糕的方法-这六种微服务RPC结构,你知道几个?

开源 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 言语内蒙古天气网,它的架构能够用下面这张图展现。

从图中你能看到,Dubbo 的架构首要包含四个人物,其间 Consumer 是服务顾客,Provider 是服务供给者,Registry 是注册中心,Monitor 是监控体系。

详细的交互流程是 Consumer 一端经过注册中心获取到 Provider 节点后,经过 Dubbo 的客户端 SDK 与 Provider 树立衔接,并建议调用。Provider 一端经过 Dubbo 的服务端 SDK 接收电饭锅做蛋糕的方法-这六种微服务RPC结构,你知道几个?到 Consumer 的恳求,处理后再把成果回来给 Consumer。

2. Motan

Motan 是国内别的一个比较有名的开源的 RPC 结构,相同也只支撑 Java 言语完结,它的架构能够用下面这张图描绘。

Motan 与 Dubbo 的架构相似,都需要在 Client 端(服务顾客)和 Server 端(服务供给者)引进 SDK,其间 Motan 结构首要包含下面几个功用模块。

register:用来和注册中心交互,包含注册服务、订阅服务、服务改变告诉、服务心跳发送等功用。

protocol:用来进行 RPC 服务的描绘和 RPC 服务的装备办理,这一层还能够增加不同功用的 filter 用来完结计算、并发约束等功用。

serialize:将 RPC 恳求中的参数、成果等目标进行序列化与反序列化

transport:用来进行长途通讯,默许运用 Netty NIO 的 TCP 长链接办法。

cluster:恳求时会依据不同的高可用与负载均衡战略挑选一个可用的 Server 建议长途调用。

3. Tars

Tars 是腾讯依据内部多年运用微服务架构的实践,总结而成的开源项目,仅支撑 C++ 言语,它的架构图如下。

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 言语朦朦胧胧,它的架构图能够用下面这张图来描绘。

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

恳求一致经过 API 网关 Zuul 来拜访内部服务,先经过 Token 进行安全认证。

经过安全认证后,网关 Zuul 从注册中心 Eureka 获取可用服务节点列表。

从可用服务节点中选取一个可用节点,然后把恳求分发到这个节点。

整个恳求过程中,Hystrix 组件担任处理服务超时熔断,Turbine 组件担任监控服务间的调用和熔断相关目标,Sleuth 组件担任调用链监控,ELK 担任日志剖析。

5. gRP电饭锅做蛋糕的方法-这六种微服务RPC结构,你知道几个?C

先来看下 gRPC,它的原理是经过 IDL(Interface Definiti电饭锅做蛋糕的方法-这六种微服务RPC结构,你知道几个?on Language)文件界说服务接口的参数和回来值类型,然后经过代码生成程序生成服务端和客户端的详细完结代码,这样在 gRPC 里,客户端使用能够像调用本地目标相同调用另一台服务器上对应的办法。

它的首要特性包含三个电饭锅做蛋糕的方法-这六种微服务RPC结构,你知道几个?方面。

通讯协议采用了 HTTP/2,由于 HTTP/2 供给了衔接复用、双向流、服务器推送、恳求优先级、首部紧缩等机制

IDL 运用了ProtoBuf,ProtoBuf 是由 Google 开发的一种数据序列化协议,它的紧缩和传输功率极高,语法也简略

多言语支撑,能够根据多种言语主动生成对应言语的客户端和服务端的代码。

6. Thrift

再来看下 Thrift,Thrift 是一种轻量级的跨言语 RPC 通讯计划,支撑多达 25 种编程言语。为了支撑多种言语,跟 gRPC 相同,Thrift 也有一套自己的接口界电饭锅做蛋糕的方法-这六种微服务RPC结构,你知道几个?说言语 IDL,能够经过代码生成器,生成各种编程言语的 Client 端和 Server 端的 SDK 代码,这样就确保了不同言语之间能够彼此通讯。它的架构图能够用下图来描绘。

从这张图上能够看出 Thrift RPC 结构的特性。

支撑多种序列化格局:如 Binary、Compact、JSON、Multiplexed 等。

支撑多种通讯办法:如 Socket、Framed、File、Memory、zlib 等。

服务端支撑多种处理办法:如 Simple 、Thread Pool、Non-Blocking 等。

作者:Java架构师追风链接:https://www.jianshu.com/p/650ccc81513f来历:简书

二维码