# rpc
**Repository Path**: mirrors_houbb/rpc
## Basic Information
- **Project Name**: rpc
- **Description**: Java rpc framework based on netty4.(java 手写 dubbo rpc 框架)
- **Primary Language**: Unknown
- **License**: Apache-2.0
- **Default Branch**: master
- **Homepage**: None
- **GVP Project**: No
## Statistics
- **Stars**: 0
- **Forks**: 0
- **Created**: 2020-08-08
- **Last Updated**: 2026-02-07
## Categories & Tags
**Categories**: Uncategorized
**Tags**: None
## README
# rpc
[rpc](https://github.com/houbb/rpc) 是基于 netty 实现的 java rpc 框架,类似于 dubbo。
[](https://travis-ci.com/houbb/rpc)
[](http://mvnrepository.com/artifact/com.github.houbb/rpc)
[](https://github.com/houbb/rpc/blob/master/LICENSE.txt)
[](https://github.com/houbb/nlp-common)
> [变更日志](https://github.com/houbb/rpc/blob/master/CHANGELOG.md)
主要用于个人学习,由渐入深,理解 rpc 的底层实现原理。
## 特性
- 基于 netty4 的客户端调用服务端
- p2p 调用
- serial 序列化支持
- timeout 超时处理
- register center 注册中心
- load balance 负载均衡
- callType 支持 oneway sync 等调用方式
- fail 支持 failOver failFast 等失败处理策略
- generic 支持泛化调用
- gracefully 优雅关闭
- rpcInterceptor 拦截器
- filter 过滤器
- check 客户端启动检测服务是否可用
- heartbeat 服务端心跳
# 快速入门
## maven 引入
```xml
com.github.houbb
rpc-all
${rpc.version}
```
ps: 如果本地 p2p 测试,register 注册中心可选。
## 测试
### 注册中心
```java
RegisterBs.newInstance().start();
```
### 服务端
```java
ServiceBs.getInstance()
.register(ServiceIdConst.CALC, new CalculatorServiceImpl())
.registerCenter(ServiceIdConst.REGISTER_CENTER)
.expose();
```
### 客户端
```java
// 服务配置信息
ReferenceConfig config = ClientBs.newInstance();
config.serviceId(ServiceIdConst.CALC);
config.serviceInterface(CalculatorService.class);
// 自动发现服务
config.subscribe(true);
config.registerCenter(ServiceIdConst.REGISTER_CENTER);
// 拦截器测试
config.rpcInterceptor(new CostTimeInterceptor());
CalculatorService calculatorService = config.reference();
CalculateRequest request = new CalculateRequest();
request.setOne(10);
request.setTwo(20);
CalculateResponse response = calculatorService.sum(request);
System.out.println(response);
```
# 前言
工作至今,接触 rpc 框架已经有很长时间。
但是对于其原理一直只是知道个大概,从来没有深入学习过。
以前一直想写,但由于各种原因被耽搁。
## 技术准备
[Java 并发实战学习](https://houbb.github.io/2019/01/18/jcip-00-overview)
[TCP/IP 协议学习笔记](https://houbb.github.io/2019/04/05/protocol-tcp-ip-01-overview-01)
[Netty 权威指南学习](https://houbb.github.io/2019/05/10/netty-definitive-gudie-00-overview)
这些技术的准备阶段,花费了比较长的时间。
也建议想写 rpc 框架的有相关的知识储备。
其他 rpc 框架使用的经验此处不再赘述。
## 快速迭代
原来一直想写 rpc,却不行动的原因就是想的太多,做的太少。
想一下把全部写完,结果就是啥都没写。
所以本次的开发,每个代码分支做的事情实际很少,只做一个功能点。
陆陆续续经过近一个月的完善,对 rpc 框架有了自己的体会和进一步的认知。
代码实现功能,主要参考 [Apache Dubbo](https://dubbo.apache.org/zh/docs/introduction/)
# 文档
## 文档
文档将使用 markdown 文本的形式,补充 code 层面没有的东西。
## 代码注释
代码有详细的注释,便于阅读和后期维护。
## 测试
目前测试代码算不上完善。后续将陆续补全。
# rpc 模块
| 模块 | 说明 |
|:---|:---|
| rpc-common | 公共代码 |
| rpc-register | 注册中心 |
| rpc-server | 服务端 |
| rpc-client | 客户端 |
| rpc-all | 全部引用模块(简化包引用) |
# 代码分支
[release_0.0.1-server 服务端启动](https://github.com/houbb/rpc/tree/release_0.0.1)
[release_0.0.2-client 客户端启动](https://github.com/houbb/rpc/tree/release_0.0.2)
[release_0.0.3-客户端调用服务端](https://github.com/houbb/rpc/tree/release_0.0.3)
[release_0.0.4-p2p 客户端主动调用服务端](https://github.com/houbb/rpc/tree/release_0.0.4)
[release_0.0.5-serial 序列化](https://github.com/houbb/rpc/tree/release_0.0.5)
[release_0.0.6-通用的反射调用](https://github.com/houbb/rpc/tree/release_0.0.6)
[release_0.0.7-timeout 超时处理](https://github.com/houbb/rpc/tree/release_0.0.7)
[release_0.0.8-register 注册中心](https://github.com/houbb/rpc/tree/release_0.0.8)
[release_0.0.9-load balance 负载均衡](https://github.com/houbb/rpc/tree/release_0.0.9)
[release_0.1.0-callType 调用方式](https://github.com/houbb/rpc/tree/release_0.1.0)
[release_0.1.1-fail 失败策略](https://github.com/houbb/rpc/tree/release_0.1.1)
[release_0.1.2-generic 泛化调用](https://github.com/houbb/rpc/tree/release_0.1.2)
[release_0.1.3-gracefully 优雅关闭](https://github.com/houbb/rpc/tree/release_0.1.3)
[release_0.1.4-rpcInterceptor 拦截器](https://github.com/houbb/rpc/tree/release_0.1.4)
# 文档说明
[0.0.1-server 服务端启动](https://github.com/houbb/rpc/blob/master/doc/dev/0.0.1-server%20服务端启动.md)
[0.0.2-client 客户端启动](https://github.com/houbb/rpc/blob/master/doc/dev/0.0.2-client%20客户端启动.md)
[0.0.3-客户端调用服务端](https://github.com/houbb/rpc/blob/master/doc/dev/0.0.3-客户端调用服务端.md)
[0.0.4-p2p 客户端主动调用服务端](https://github.com/houbb/rpc/blob/master/doc/dev/0.0.4-p2p客户端主动调用服务端.md)
[0.0.5-serial 序列化](https://github.com/houbb/rpc/blob/master/doc/dev/0.0.5-serial序列化.md)
[0.0.6-通用反射调用](https://github.com/houbb/rpc/blob/master/doc/dev/0.0.6-通用反射调用.md)
[0.0.7-timeout 超时处理](https://github.com/houbb/rpc/blob/master/doc/dev/0.0.7-timeout超时处理.md)
[0.0.8-register 注册中心](https://github.com/houbb/rpc/blob/master/doc/dev/0.0.8-register注册中心.md)
[0.0.9-load balance 负载均衡](https://github.com/houbb/rpc/blob/master/doc/dev/0.0.9-load-balance-负载均衡.md)
[0.1.0-callType 调用方式](https://github.com/houbb/rpc/blob/master/doc/dev/0.1.0-callType-调用方式.md)
[0.1.1-fail 失败策略](https://github.com/houbb/rpc/blob/master/doc/dev/0.1.1-fail-失败策略.md)
[0.1.2-generic 泛化调用](https://github.com/houbb/rpc/blob/master/doc/dev/0.1.2-generic-泛化调用.md)
[0.1.3-gracefully 优雅关闭](https://github.com/houbb/rpc/blob/master/doc/dev/0.1.3-gracefully-优雅关闭.md)
[0.1.4-rpcInterceptor 拦截器](https://github.com/houbb/rpc/blob/master/doc/dev/0.1.4-rpcInterceptor-拦截器.md)
# 测试代码
从 v0.0.6 及其之后,为了让代码保持纯净,将测试代码全部放在 rpc-example。
每个测试代码和实现版本一一对应。
ps: 这部分测试代码可以关注公众号【老马啸西风】,后台回复【rpc】领取。

# 后期 ROAD-MAP
- [x] all 模块
- [x] check 客户端启动检测
- [x] register 是否注册到注册中心
- [x] delay 延迟暴露
- [x] 关闭时通知 register center
- [x] 优雅关闭添加超时设置
- [x] heartbeat 心跳检测机制
- [x] 完善 load-balance 实现
- [x] 完善 filter 实现
- [x] 完善 rpcInterceptor 实现
- [ ] 失败重试的拓展
尝试其他服务端
指定重试策略(sisyphus)
- [ ] route 路由规则
可以和 echo 回声检测一起实现
- [ ] echo 回声服务
- [ ] spring 整合
- [ ] springboot 整合
- [ ] telnet 命令行治理
- [ ] rpc-admin 控台管理
服务治理
- [ ] async 异步执行
- [ ] ~~cache 结果缓存?~~
- [ ] ~~validator 参数校验~~
- [ ] ~~服务降级~~
- [ ] ~~version 多版本管理~~
# 中间件等工具开源矩阵
[heaven: 收集开发中常用的工具类](https://github.com/houbb/heaven)
[rpc: 基于 netty4 实现的远程调用工具](https://github.com/houbb/rpc)
[mq: 简易版 mq 实现](https://github.com/houbb/mq)
[ioc: 模拟简易版 spring ioc](https://github.com/houbb/ioc)
[mybatis: 简易版 mybatis](https://github.com/houbb/mybatis)
[cache: 渐进式 redis 缓存](https://github.com/houbb/cache)
[jdbc-pool: 数据库连接池实现](https://github.com/houbb/jdbc-pool)
[sandglass: 任务调度时间工具框架](https://github.com/houbb/sandglass)
[sisyphus: 支持注解的重试框架](https://github.com/houbb/sisyphus)
[resubmit: 防止重复提交框架,支持注解](https://github.com/houbb/resubmit)
[auto-log: 日志自动输出](https://github.com/houbb/auto-log)
[async: 多线程异步并行框架](https://github.com/houbb/async)