痛点
1. bsf底层依赖springcloud,影响bsf更新springboot新版本和整体最新技术版本升级。
2. eureka已经闭源,且框架设计较重,同时引入eureka会自行引入较多springcloud相关包和组件。
方案
1. 自研轻量级高性能rpc框架Bsf APIRegistry。
目标
Bsf APIRegistry需要解决的关键痛点:
1. 代码简单,简单,简单!框架实现要轻量,容易扩展,这样性能扩展也会很高。
2. 要兼容旧项目@FeignClient,业务开发零改造代码,实现业务零感知无缝迁移。
3. 引入的第三方组件越少越好,以后bsf组件冲突问题也会少。(本地服务启动时间应该也会比eureka注册中心快很多)
4. 高性能,高扩展能力,可以支持未来服务上万节点在线。
5. 解决现有本地调试痛点。(开发环境在阿里云容器中,要实现多人开发本地测试在线联调!)
6. 支持无注册中心方式使用和无缝迁移。(可以借助k8s自带负载均衡网关,兼容场景并使用无注册中心架构)
技术要求
Bsf APIRegistry需要具备几个关键技术点:
- 支持HttpUrlConnection,HttpClient建立的连接池及扩展。
- 支持轮训模式负载均衡及扩展。
- 支持消费者端检测故障,临时转移到可用服务,待服务故障恢复后恢复调用。
- 支持redis注册中心及扩展,以及无注册中心架构。
- 支持protobuf协议,整体rpc性能会有较大提升。