RCP框架

对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。
  • 大致的运行流程是:首先启动容器,服务提供方在注册中心发布注册自己要提供的服务,服务消费方在注册中心订阅自己所需的服务,并且服务提供方和消费方在内存中累计调用次数和调用时间,定时每分钟发送一次统计数据给监控中心。
  • 服务方把它要暴露的服务和地址信息注册到注册中心,客户端订阅注册中心,如果服务端地址发生改变,它会再次注册到注册中心,然后注册中心会通知客户端。
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值