如何设计一个RPC框架?

简介: 如何设计一个RPC框架?

很多语言都内置了RPC技术。

Java RMI

.NET Remoting

远古时期,就有很多尝试:


  • Corba(Common ObjectRequest Broker Architecture)公共对象请求代理体系结构,OMG组织在1991年提出的公用对象请求代理程序结构的技术规范。底层结构是基于面向对象模型的,由OMG接口描述语言(OMG Interface Definition Language,OMG IDL)、对象请求代理(Objec tRequest Broker,ORB)和IIOP标准协议(Internet Inter ORB Protocol,也称网络ORB交换协议)3个关键模块组成。
  • COM(Component Object Model,组件对象模型)是微软公司于1993年提出的一种组件技术,它是一种平台无关、语言中立、位置透明、支持网络的中间件技术。很多老一辈程序员心目中的神书《COM本质论》。


1 从使用者考虑

定义过程接口

11.png

客户端使用生成的stub代理对象

12.png

2 客户端的设计

客户端生成过程接口的代理对象。

客户端代理工厂,用JDK动态代理(或者 AOP 实现)即可生成接口的代理对象。

13.png

  • ClientStubInvocationHandler


14.png

  • 消息协议是固定不变的吗?它与什么有关?
    看框架对协议的支持广度,如果支持多种协议,就是会灵活变化的,它与具体的服务相关,
    A服务提供者可能选用的是协议1,B服务提供者可能选用协议2。
  • 某服务是用的什么消息协议这个信息从哪来?
    从获取的服务信息中来,因此需要一个服务信息发现者。


把发现者设计出来, 要求:可灵活支持多种发现机制


15.png16.png

  • 想要做到可以支持多种协议,类该如何设计?面向接口、策略模式、组合

17.png

问题:

➢ marshalling和unmarshalling方法该定义怎样的参数与返回值?

➢ 编组、解组的操作对象是请求、响应,请求、响应的内容是不同的。编组、解组两个方法是否满足?


设计客户端协议层

定义框架标准的请求, 响应类

18.png


将协议层扩展为四个


19.png


  1. 消息协议独立为一层(客户端、服务端均需要)

网络层

发送请求,获得响应

要发起网络请求,则须知道服务地址


20.png

  • 客户端完整类图


image.png



在实现过程中,协议层涉及一个重要概念

  • 参数序列化、反序列


3 设计服务端

3.1 RPCServer

客户端请求过来了,服务端首先需要通过RPCServer接收请求。

22.png23.png

  • RPCServer


24.png


3.2 思考

RPCServer接收到客户端请求后,还需要做哪些工作?

image.png

网络层在RPCServer中提供多线程来处理请求,消息协议层复用客户端设计的。

(设计一个请求处理类,来完成网络层以上的事情。)


3.3 RequestHandler

RPCServer接收到请求后,将请求交给RequestHandler来处理

RequestHandler调用协议层来解组请求消息为Request对象,然后调用过程!

26.png

人性的拷问

➢ RequestHandler如何得到过程对象?

➢ Request中有什么?

➢ 服务名、方法名、参数类型、参数值

➢ 是否需要一个过程注册模块?

看看之后的设计


image.png

过程注册模块:让用户将他们的过程注册到RPC框架

过程暴露模块:想对外发布(暴露)服务注册、暴露可以由同一个类实现

image.png

  1. RPCServer 中实现网络层: Netty, 使用RequestHandler
  2. ServiceRegister 模块实现服务注册、发布。
  3. RequestHandler 中实现消息协议处理、过程调用


代码实现

  • 首先,用户需要设置你的端口和协议哦

29.png30.png




目录
相关文章
|
8月前
|
负载均衡 Dubbo Java
Dubbo 3.x:探索阿里巴巴的开源RPC框架新技术
随着微服务架构的兴起,远程过程调用(RPC)框架成为了关键组件。Dubbo,作为阿里巴巴的开源RPC框架,已经演进到了3.x版本,带来了许多新特性和技术改进。本文将探讨Dubbo 3.x中的一些最新技术,包括服务注册与发现、负载均衡、服务治理等,并通过代码示例展示其使用方式。
422 9
|
8月前
|
JSON 负载均衡 网络协议
Rpc编程系列文章第二篇:RPC框架设计目标
Rpc编程系列文章第二篇:RPC框架设计目标
|
8月前
|
设计模式 负载均衡 网络协议
【分布式技术专题】「分布式技术架构」实践见真知,手把手教你如何实现一个属于自己的RPC框架(架构技术引导篇)
【分布式技术专题】「分布式技术架构」实践见真知,手把手教你如何实现一个属于自己的RPC框架(架构技术引导篇)
309 0
|
8月前
|
Dubbo Java 应用服务中间件
Rpc编程系列文章第三篇:Hessian RPC一个老的RPC框架
Rpc编程系列文章第三篇:Hessian RPC一个老的RPC框架
|
2月前
|
自然语言处理 负载均衡 API
gRPC 一种现代、开源、高性能的远程过程调用 (RPC) 可以在任何地方运行的框架
gRPC 是一种现代开源高性能远程过程调用(RPC)框架,支持多种编程语言,可在任何环境中运行。它通过高效的连接方式,支持负载平衡、跟踪、健康检查和身份验证,适用于微服务架构、移动设备和浏览器客户端连接后端服务等场景。gRPC 使用 Protocol Buffers 作为接口定义语言,支持四种服务方法:一元 RPC、服务器流式处理、客户端流式处理和双向流式处理。
|
5月前
|
Dubbo 网络协议 Java
RPC框架:一文带你搞懂RPC
这篇文章全面介绍了RPC(远程过程调用)的概念、原理和应用场景,解释了RPC如何工作以及为什么在分布式系统中广泛使用,并探讨了几种常用的RPC框架如Thrift、gRPC、Dubbo和Spring Cloud,同时详细阐述了RPC调用流程和实现透明化远程服务调用的关键技术,包括动态代理和消息的编码解码过程。
RPC框架:一文带你搞懂RPC
|
4月前
|
XML 负载均衡 监控
分布式-dubbo-简易版的RPC框架
分布式-dubbo-简易版的RPC框架
|
7月前
|
存储 缓存 Linux
【实战指南】嵌入式RPC框架设计实践:六大核心类构建高效RPC框架
在先前的文章基础上,本文讨论如何通过分层封装提升一个针对嵌入式Linux的RPC框架的易用性。设计包括自动服务注册、高性能通信、泛型序列化和简洁API。框架分为6个关键类:BindingHub、SharedRingBuffer、Parcel、Binder、IBinder和BindInterface。BindingHub负责服务注册,SharedRingBuffer实现高效数据传输,Parcel处理序列化,而Binder和IBinder分别用于服务端和客户端交互。BindInterface提供简单的初始化接口,简化应用集成。测试案例展示了客户端和服务端的交互,验证了RPC功能的有效性。
451 8
|
5月前
|
XML 存储 JSON
(十二)探索高性能通信与RPC框架基石:Json、ProtoBuf、Hessian序列化详解
如今这个分布式风靡的时代,网络通信技术,是每位技术人员必须掌握的技能,因为无论是哪种分布式技术,都离不开心跳、选举、节点感知、数据同步……等机制,而究其根本,这些技术的本质都是网络间的数据交互。正因如此,想要构建一个高性能的分布式组件/系统,不得不思考一个问题:怎么才能让数据传输的速度更快?
126 1
|
6月前
|
分布式计算 负载均衡 数据安全/隐私保护
什么是RPC?有哪些RPC框架?
RPC(Remote Procedure Call,远程过程调用)是一种允许运行在一台计算机上的程序调用另一台计算机上子程序的技术。这种技术屏蔽了底层的网络通信细节,使得程序间的远程通信如同本地调用一样简单。RPC机制使得开发者能够构建分布式计算系统,其中不同的组件可以分布在不同的计算机上,但它们之间可以像在同一台机器上一样相互调用。
171 8