RPC关键技术

RPC 使用了哪些关键技术?

  1. 动态代理

    生成 Client Stub(客户端存根)和 Server Stub(服务端存根)的时候需要用到 Java 动态代理技术,可以使用 JDK 提供的原生的动态代理机制,也可以使用开源的:CGLib 代理,Javassist 字节码生成技术。

  2. 序列化和反序列化

    在网络中,所有的数据都将会被转化为字节进行传送,所以为了能够使参数对象在网络中进行传输,需要对这些参数进行序列化和反序列化操作。

    序列化:把对象转换为字节序列的过程称为对象的序列化,也就是编码的过程。

    反序列化:把字节序列恢复为对象的过程称为对象的反序列化,也就是解码的过程。

    目前比较高效的开源序列化框架:如 Kryo、FastJson 和 Protobuf 等。

  3. NIO通信

    出于并发性能的考虑,传统的阻塞式 IO 显然不太合适,因此我们需要异步的 IO,即 NIO。Java 提供了 NIO 的解决方案,Java 7 也提供了更优秀的 NIO.2 支持。可以选择 Netty 或者 MINA 来解决 NIO 数据传输的问题。

  4. 服务注册中心

    可选:Redis、 Zookeeper、 Consul、 Etcd。一般使用 ZooKeeper 提供服务注册与发现功能,解决单点故障以及分布式部署的问题(注册中心)。