源码:https://github.com/codermokeywang/rpc
简介
参考https://www.imooc.com/video/21092课程实现的轻量化框架
rpc核心原理,相关技术介绍
RPC:Remote Procedure Call,即远程过程调用。是分布式系统常见的一种通信方法,从跨进程与跨物理机已经有几十年历史。 跨进程交互形式:RESTful、WebService、HTTP,基于DB做数据交换、基于MQ做数据交换、以及RPC。交互形式分为以下两种。
依赖中间件做数据交互
优点:解耦合、异步 缺点:系统复杂性提高、可用性降低
直接交互
优点:系统复杂性底、速度快 缺点:耦合性高、客户端需要等待服务端的返回。
分析现有RPC框架
核心原理
核心过程
技术栈
-
基础知识 JAVACore、Maven、反射 -
动态代理(生成client存根实际调用对象) java的动态代理 -
序列化(Java对象与二进制数据互转) fastjson 序列化:java对象转为二进制数组 反序列化:二进制数组转为java对象 -
网络通信(传输序列化后的数据):jetty、URLConnectin
代码实现
- 创建工程、制定协议、通用工具方法
- 实现序列化模块
- 实现网络模块
- 实现Server模块
- 实现Client模块
- 使用案例
类图
设计思路
1.定义模块
1.rpc-common:相关公共类,反射工具 2.rpc-codec:序列化与反序列化 3.rpc-protocol:网络协议 4.rpc-transport:传输协议 5.rpc-server:服务端 6.rpc-client:客户端 7.rpc-example:测试用例
|