thrift加密
发布时间: 2025-10-02 03:27:15
⑴ 【网络】一文带你了解什么是RPC
一文带你了解什么是RPC
RPC(Remote Procere Call Protocol)远程过程调用协议,是一种通过网络从远程计算机程序上请求服务,而不需要了解底层网络技术的协议。简言之,RPC使得程序能够像访问本地系统资源一样,去访问远端系统资源。
一、RPC的关键方面
RPC涉及的关键方面包括:通讯协议、序列化、资源(接口)描述、服务框架、性能、语言支持等。简单来说,RPC就是从一台机器(客户端)上通过参数传递的方式调用另一台机器(服务器)上的一个函数或方法(可以统称为服务)并得到返回的结果。
二、RPC架构组件
一个基本的RPC架构应该至少包含以下四个组件:
- 客户端(Client):服务调用方,即服务消费者。
- 客户端存根(Client Stub):存放服务端地址信息,将客户端的请求参数数据信息打包成网络消息,再通过网络传输发送给服务端。
- 服务端存根(Server Stub):接收客户端发送过来的请求消息并进行解包,然后再调用本地服务进行处理。
- 服务端(Server):服务的真正提供者。
三、RPC的具体调用过程
- 服务消费者(Client客户端)通过调用本地服务的方式调用需要消费的服务。
- 客户端存根(Client Stub)接收到调用请求后,负责将方法、入参等信息序列化(组装)成能够进行网络传输的消息体。
- 客户端存根(Client Stub)找到远程的服务地址,并将消息通过网络发送给服务端。
- 服务端存根(Server Stub)收到消息后进行解码(反序列化操作)。
- 服务端存根(Server Stub)根据解码结果调用本地的服务进行相关处理。
- 本地服务执行具体业务逻辑,并将处理结果返回给服务端存根(Server Stub)。
- 服务端存根(Server Stub)将返回结果重新打包成消息(序列化)并通过网络发送至消费方。
- 客户端存根(Client Stub)接收到消息,并进行解码(反序列化)。
- 服务消费方得到最终结果。
RPC框架的实现目标是将上述过程完好地封装起来,让用户感觉上像调用本地服务一样调用远程服务。
四、RPC与相关技术或概念的区别
- REST:可以看作是HTTP协议的一种直接应用,默认基于JSON作为传输格式,使用简单,学习成本低效率高,但安全性较低。
- SOAP:是一种数据交换协议规范,是一种轻量的、简单的、基于XML的协议的规范。SOAP在安全方面是通过使用XML-Security和XML-Signature两个规范组成了WS-Security来实现安全控制的。
- SOA:面向服务架构,它可以根据需求通过网络对松散耦合的粗粒度应用组件进行分布式部署、组合和使用。SOA是一种粗粒度、松耦合服务架构,服务之间通过简单、精确定义接口进行通讯,不涉及底层编程接口和通讯模型。
五、RPC框架需要解决的问题
- 如何确定客户端和服务端之间的通信协议?
- 如何更高效地进行网络通信?
- 服务端提供的服务如何暴露给客户端?
- 客户端如何发现这些暴露的服务?
- 如何更高效地对请求对象和响应结果进行序列化和反序列化操作?
六、RPC的实现基础
- 需要有非常高效的网络通信,比如一般选择Netty作为网络通信框架。
- 需要有比较高效的序列化框架,比如谷歌的Protobuf序列化框架。
- 可靠的寻址方式(主要是提供服务的发现),比如可以使用Zookeeper来注册服务等等。
- 如果是带会话(状态)的RPC调用,还需要有会话和状态保持的功能。
七、RPC使用的关键技术
- 动态代理:生成Client Stub和Server Stub时需要用到java动态代理技术,可以使用JDK提供的原生的动态代理机制,也可以使用开源的CGLib代理、Javassist字节码生成技术。
- 序列化和反序列化:在网络中,所有的数据都将会被转化为字节进行传送。为了能够使参数对象在网络中进行传输,需要对这些参数进行序列化和反序列化操作。目前比较高效的开源序列化框架有Kryo、FastJson和Protobuf等。
- NIO通信:出于并发性能的考虑,传统的阻塞式IO显然不太合适,因此我们需要异步的IO,即NIO。Java提供了NIO的解决方案,Java 7也提供了更优秀的NIO.2支持。可以选择Netty或者MINA来解决NIO数据传输的问题。
- 服务注册中心:可选Redis、Zookeeper、Consul、Etcd等。一般使用ZooKeeper提供服务注册与发现功能,解决单点故障以及分布式部署的问题。
八、主流RPC框架
- RMI:利用java.rmi包实现,基于Java远程方法协议(Java Remote Method Protocol)和Java的原生序列化。
- Hessian:一个轻量级的remoting on http工具,使用简单的方法提供了RMI的功能。基于HTTP协议,采用二进制编解码。
- protobuf-rpc-pro:一个Java类库,提供了基于Google的Protocol Buffers协议的远程方法调用的框架。基于Netty底层的NIO技术,支持TCP重用/keep-alive、SSL加密、RPC调用取消操作、嵌入式日志等功能。
- Thrift:一种可伸缩的跨语言服务的软件框架。它拥有功能强大的代码生成引擎,无缝地支持C++、C#、Java、Python、PHP和Ruby等多种语言。Thrift允许定义一个描述文件,描述数据类型和服务接口。依据该文件,编译器方便地生成RPC客户端和服务器通信代码。
- Avro:出自Hadoop之父Doug Cutting,旨在建立一个新的、标准性的云计算的数据交换和存储的Protocol。支持HTTP、TCP两种协议。
- Dubbo:阿里巴巴公司开源的一个高性能优秀的服务框架,使得应用可通过高性能的RPC实现服务的输出和输入功能,可以和Spring框架无缝集成。
综上所述,RPC是一种强大的网络通信技术,通过封装复杂的底层细节,使得远程服务调用变得像本地服务调用一样简单方便。
热点内容