对RPC框架的理解
- RPC的意思是远程过程调用,可以像调用本地方法那样调用远程方法。
- 跨进程的交互方式有:RPC、RESTful、HTTP、WebServer、基于MQ或者数据库做数据交互。它们可以分为两种,一种是依赖中间件做数据交互:数据库、Redis、MQ。另一种是客户端和服务端的直接交互:RPC、RESTful、HTTP、WebServer。
RPC组件和流程:
-
客户端 Client:服务消费者,调用远程服务。
-
客户端存根 client stub:将用户的请求参数打包发给服务端。
-
服务端存根 server stub:收到信息后进行解码并调用本地服务。
-
本地服务执行完后,将结果返回给服务端存根。
-
服务端存根将结果打包发给客户端。
-
客户端存根接收到消息后进行解码得到最终结果。
-
还有一个服务注册中心 Registry。服务方把它要暴露的服务和地址信息注册到注册中心,Client 订阅注册中心,如果 Server 地址发生改变,它会再次注册到注册中心,然后注册中心会通知 Client。Client 调用 Server 。
RPC框架有哪些?
阿里的 dubbo:
- 通过 hession2 序列化
- 注册中心一般采用的 zookeeper
- 不能跨语言
谷歌的 gRPC:
- 通过 protobuf 序列化
- 可以跨语言
Dubbo
- Dubbo 是阿里开源的一种RPC框架,它的结构主要由五部分组成:暴露服务的服务提供方 Provider,调用远程服务的服务消费方 Consumer,注册中心 Registry,统计服务调用次数和调用时间的监控中心 Monitor,服务运行容器 Container。
- 大致的运行流程是:首先启动容器,服务提供方在注册中心发布注册自己要提供的服务,服务消费方在注册中心订阅自己所需的服务,并且服务提供方和消费方在内存中累计调用次数和调用时间,定时每分钟发送一次统计数据给监控中心。
- 服务方把它要暴露的服务和地址信息注册到注册中心,客户端订阅注册中心,如果服务端地址发生改变,它会再次注册到注册中心,然后注册中心会通知客户端。