目录
百战程序员,全站22050+开发课程+文档 ,学习精选优质好课快人一步!观看视频 快捷键ALT+N

JAVA全系列 教程

3762个小节阅读:7095.2k

收藏
全部开发者教程

C语言快速入门

JAVA全系列 教程

面向对象的程序设计语言

Python全系列 教程

Python3.x版本,未来主流的版本

人工智能 教程

顺势而为,AI创新未来

大厂算法 教程

算法,程序员自我提升必经之路

C++ 教程

一门通用计算机编程语言

微服务 教程

目前业界流行的框架组合

web前端全系列 教程

通向WEB技术世界的钥匙

大数据全系列 教程

站在云端操控万千数据

AIGC全能工具班

A

A A

White Night

阅读(216)
赞(0)

12、华为二面,如何设计一个类似 Dubbo的RPC框架?架构上该如何考虑?

RPC是Remote Procedure Call 的缩写,即远程过程调用。

RPC 是一个计算机通信协议。该协议允许运行于一台计算机的程序调用另一台计算机的子程序,而开发人员无需额外地为这个交互编程。

使用RPC调用远程服务器上的应用程序就像调用本地程序一样, 那么就应该生成代理来隐藏调用远程服务的细节。

一个完整的RPC框架中包含的核心组件

  • 客户端(Client),服务的调用方。
  • 客户端存根(Client Stub),存放服务端的地址消息,再将客户端的请求参数打包成网络消息,然后 通过网络远程发送给服务方。
  • 服务端(Server),真正的服务提供者。
  • 服务端存根(Server Stub),接收客户端发送过来的消息,将消息解包,并调用本地的方法。

image-20230424161618251

设计RPC 框架时应该关注哪些东西?

  • 服务发现与服务注册

    如果我们想在 Service A 中调用 Service B,那么我们首先得知道 Service B 的地址。 所以,我们需要有一个服务注册中心,通过这个中心,服务可以把自己的信息注册进来,也可以获取到别的服务的信息。客户端也需要watch服务注册中心的目标服务的地址的变化。

  • 网络通信

    • 服务和服务之间的网络通信模型, NIO/IO 等等
    • 客户端如何复用与服务端的连接, 而不是每次请求都重新创建一个新连接?
    • 客户端收到返回后,如何知道是哪个请求的返回并且做出正确处理?
  • 消息的序列化

    服务间通信的消息通过什么方式进行序列化? Hessian,XML、JSON……, 甚至 Java 原生的序列化方式。

  • 负载均衡

    • 根据服务实例的 metrics 做出动态调整, 比如响应时间等
    • 利用一致性哈希, 提高本地缓存利用率
  • 容灾

    • 健康监测 在某一个服务节点挂掉的时候, 如何在服务注册中心删去这个服务地址?
    • 服务调用超时与重试 在调用一个服务实例的时候,如果超时或者报错,怎么处理?
    • 服务限流 如何限制最大并发数?这个又可以从客户端和服务端两个角度分析。

 

北京市昌平区回龙观镇南店村综合商业楼2楼226室

©2014-2023 百战卓越(北京)科技有限公司 All Rights Reserved.

京ICP备14032124号-2