RPC协议及实现方式(分布式微服务治理的核心)

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了RPC协议及实现方式(分布式微服务治理的核心)相关的知识,希望对你有一定的参考价值。

参考技术A

分布式微服务治理的核心在于: 微服务和分布式

Remote Procedure Call,翻译过来应该是“远程程序调用”,目前业内通用的翻译是“远程过程调用”,但是“过程”这个词很容易造成误解,翻译成“程序”更好理解RPC的意义。

一般所谓的XX协议就是个文档,类似于我们的需求文档,只说了要做什么,但是具体怎么做是由各大开源大佬做的。 一般情况下都会实现核心功能,不同的开源在细节上实现都会不一样,这个需要注意!

RPC 这个概念术语在上世纪 80 年代由 Bruce Jay Nelson 提出的,在 Nelson 的论文 "Implementing Remote Procedure Calls" 中,他提到了几个 RPC的特点 :

除此之外,这位大佬还给出了实现RPC框架的 详细架构图 :

结合上图,Nelson 的论文中指出实现 RPC 的程序包括 5 个部分:

所以这架构图的意思是:当 user 想发起一个远程调用时,它实际是通过本地调用 User-stub。并通过本地的RPCRuntime传输 。远端 RPCRuntime 实例收到请求后交给 Server-stub 进行解码后发起本地端调用,调用结果再返回给 User 端。

看完协议内容,跟着就得实现这个协议啦,这时候你是不是发现了问题的严重性: 自!己!一!点!思!路!都!没!有!

所以我们需要再理解一下RPC协议,根据Nelson的论文知道我们要做的两件事:

上述两点其实是实现RPC协议的两大要素: 序列化协议和传输协议

因为RPC本质上是进程间通信,而“本地调用和远程调用的对比”实际上就是“进程内通信和进程间通信的对比”。通过两者的对比,我们才能理解到 序列化协议和传输协议 的作用,如下图:

最基本的RPC框架就是 单点式 的,因为A服务直接调用B服务,不经过第三方,这种是最简单的。但是必须是A和B同时部署一套,A1只能调用B1,A2只能调用B2。

所以需要一台A服务对多台B服务,利用第三方服务(注册中心)找到其他B服务,而不是写死B服务的地址。这种RPC才是 分布式 RPC,也是业内主流。

单点RPC框架只需要:

但是我们要做分布式的啊,所以需要:

实际上在生产环境中,我们需要实时监控服务的调用情况,所以需要一个微服务管理中心,甚至是一个自动化运维的管理中心,所以需要:

在文章的第二节我们看到大佬论文中对RPC的总结,其中一个很重要的一点:“通用”。

所以我们需要:

对的,能实现上述五点的,才是一个合格的RPC框架,但还不是优秀,因为我们还要考虑下性能。

先打个底,目前流行的RPC框架大多都是多管闲事,不单单只是RPC框架,你可以看看Dubbo和SpringCloud中除了RPC还有什么骚功能。

可以看看别人的各种RPC框架总结: http://www.cnblogs.com/moonandstar08/p/6291283.html
在网上找到了个图,但是没有提到SpringCloud,暂且看看先,因为有些不认为是对的:

我们可以看到各个RPC框架使用的序列化协议,注册中心,管理中心,是否跨语言,但是传输协议没有提到。

参考这篇博客: http://blog.csdn.net/jek123456/article/details/70208049
综合来说,在性能上rpcx是首选,但是考虑到框架的生态,其实还是推荐Dubbo或者SpringCloud的,因为除了性能,成本也是很重要的,无论是学习成本还是研发成本。

分布式微服务治理框架-选型

分布式微服务治理框架-选型


目录

1、同类产品对比选型

2、注册中心

3、配置中心

4、服务通信

5、负载均衡

6、降级机制

7、服务网关


1、同类产品对比选型

降级框架主要有SpringCloudNetflix、Dubbo、SpringCloudAlibaba,当然我们也可以混用,分布式微服务治理框架一般包含注册中心、配置中心、服务通信、负载均衡、熔断机制、服务网关。

Spring Cloud NetflixDubboSpring Cloud Alibaba
注册中心EurekaZookeeperNacos
配置中心Spring Cloud ConfigNacos
服务通信FeignRPC
负载均衡Ribbon客户端负载客户端负载
降级机制HystrixSentinel
服务网关Zuul、GatewayGateway

2、注册中心

注册中心主要有Eureka、Consul、Nacos、Zookeeper

注册中心面试题大全

3、配置中心

配置中心主要有Apollo、Spring Cloud Config、Nacos

配置中心面试题大全

4、服务通信

服务通信方式主要有HTTP/S、Feign、Dubbo-RPC、异步MQ

服务通信面试题大全

5、负载均衡

配置中心主要有Apollo、Spring Cloud Config、Nacos

负载均衡面试题大全

6、降级机制

降级框架主要有Spring Cloud Hystrix、Sentinel、Resilience4j

降级面试题大全

7、服务网关

服务网关主要有Zuul1、Zuul2、Spring Cloud GateWay、OpenResty

服务网关面试题大全

以上是关于RPC协议及实现方式(分布式微服务治理的核心)的主要内容,如果未能解决你的问题,请参考以下文章

分布式RPC框架Dubbo实现服务治理:集成Kryo实现高速序列化,集成Hystrix实现熔断器

分布式微服务治理框架-选型

一个开源分布式微服务RPC框架 ~ 2.0版本问世

一个开源分布式微服务RPC框架 ~ 正式发布

一文理解分布式开发中的服务治理

Dubbo实现源码分析