痛点

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性能会有较大提升。

架构示意图

整体参考按照eureka的技术原理,以bsf-core框架(https://gitee.com/chejiangyi/free-bsf-all/)为核心,优先扩展实现redis注册中心方案。同时整体架构考虑eureka注册中心的兼容性使用,@feignClient注解的feign的兼容性api协议编写,支持双注册中心部署和无缝迁移方案,从而达到开发人员零改动,无感知的目标。
同时redis单机可以支持上万客户端链接,同样redis也支持主从高可用分布式部署,故采用redis做注册中心也可以支持上万的分布式服务节点同时在线和注册中心高可用支持。在框架层面注册中心抽象剥离实现可扩展,也可以为更好更高性能的注册中心实现做扩展能力支持。
 

消费者端RPC调用生命周期图

整体rpc调用会经历客户端@ApiClient(兼容@FeignClient注解)协议解析为RPC Request信息,通过RPC负载均衡器获取服务列表的可用节点(排除故障节点),进行RPC编码器进行编码(json或者protobuf等),再通过RPC 连接池(http连接池)获取可用tcp连接调用远程rpc结果,然后对rpc结果进行RPC解码器解码,最终返回RPC对象结果。
 

消费者端RPC启动初始化

整体rpc框架启动时会经历一次初始化,通过包扫描@ApiClient(兼容@FeignClient注解)相关的协议接口类,会对协议接口类进行透明代理,并注册代理实例到springboot bean中。
 

兼容eureka模式的无缝迁移方案

为了保证无缝迁移和开发人员无感知,在bsf sdk层面对@FeignClient(feign调用)做协议兼容支持,这样理论上开发人员无需改动旧代码;同时2.1 版本bsf sdk层面实现双注册中心兼容(支持eureka server和bsf ApiRegistriy同时在线)去确保平滑迁移;在bsf sdk中加入“测试模式”,通过apollo配置中心动态修改模式,支持框架层面随时切换使用eureka server和ApiRegistry任意注册中心调用rpc,也可以对rpc结果进行同步核对结果集校验+动态报警(确保协议兼容验证)来确保可以兼容稳定迁移和迁移实时回滚。
 

ApiRegistry开源地址

包含源码,更多详细配置,实践和场景支持记录。

源码核心模块

其中核心类就两三个,源码总共也就10几个类,代码简单,逻辑简单(核心就是为了轻量!!!),一般在10分钟就可以看明白整体结构和代码。
 

小白快速上手

  • 引用包
<dependency>
<artifactId>free-bsf-api</artifactId>
<groupId>com.free.bsf</groupId>
<version>2.2-SNAPSHOT</version>
</dependency>
<dependency>
<artifactId>free-bsf-core</artifactId>
<groupId>com.free.bsf</groupId>
<version>2.2-SNAPSHOT</version>
</dependency>
<dependency>
<artifactId>free-bsf-apiregistry</artifactId>
<groupId>com.free.bsf</groupId>
<version>2.2-SNAPSHOT</version>
</dependency>
free-bsf-api:为协议包,包含ApiRegistry通用协议,用在业务项目协议层。
free-bsf-core:为bsf核心包,一般为工具类为主。
free-bsf-apiregistry:为bsf ApiRegistry实现包。
 
  • properties配置:
#springboot 应用名
spring.application.name=free-demo-provider
#一键启用开关,默认false,重启后生效
bsf.apiRegistry.enabled=true
#支持ApiClient/FeignClient注解方式的Rpc拦截,重启后生效,默认false
bsf.apiRegistry.apiClientAspect.enabled=true
#rpcClient 扫描@ApiClient/@FeignClient注解的包,以逗号分割多个【rpc调用必填】
bsf.apiRegistry.rpcClient.basePackages=com.xxxx.xxxx
#注册中心redis实现的,redis地址格式:127.0.0.1:6379(无密码登陆)
bsf.apiRegistry.registry.redis.host=XXX.XXX.XXX.XXX:6379
  • api协议代码示例
//兼容@FeginClient
@ApiClient(name = "lmc-test-provider",path = "/")
public interface CustomerProvider {
/*接口协议定义*/
//支持GetMapping,PostMapping
@PostMapping("/test")
//支持@RequestParam,@RequestBody
ApiResponseEntity<String> test(@RequestParam("str") String str);
}

总结

ApiRegistry 为近期技术问题解决的随手之作,虽自测无太大问题,但目前还需要真实迁移落地和技术升级(包括可能的bug修复)。
技术无捷径,勤做笔记,点滴进步,与君共勉!!!
 
 
by 车江毅
技术vp
2022-12-15
 
 
其他博文:
高效能全链路性能压测笔记 https://www.cnblogs.com/chejiangyi/p/16900586.html
五个维度打造研发管理体系 https://www.cnblogs.com/chejiangyi/p/15420637.html
高效能研发体系建设概论 https://www.cnblogs.com/chejiangyi/p/15000543.html

自研分布式高性能RPC框架及服务注册中心实践笔记【原创】【开源】的更多相关文章

  1. 基于Protobuf的分布式高性能RPC框架——Navi-Pbrpc

    基于Protobuf的分布式高性能RPC框架——Navi-Pbrpc 二月 8, 2016 1 简介 Navi-pbrpc框架是一个高性能的远程调用RPC框架,使用netty4技术提供非阻塞.异步.全 ...

  2. 从零开始实现简单 RPC 框架 4:注册中心

    RPC 中服务消费端(Consumer) 需要请求服务提供方(Provider)的接口,必须要知道 Provider 的地址才能请求到. 那么,Consumer 要从哪里获取 Provider 的地址 ...

  3. RPC框架的服务注册和发现

    https://www.cnblogs.com/valor-xh/p/6281502.html https://blog.csdn.net/listslim1/article/details/5157 ...

  4. C# -- 高性能RPC框架:Socean.RPC

    简介 Socean.RPC是一个.Net下的高性能RPC框架,框架以高性能.高稳定性为目标,底层基于socket,无第三方库引用,代码简洁,总代码量大约在2000行,框架性能较高,在普通PC上测试,长 ...

  5. (五):C++分布式实时应用框架——微服务架构的演进

    C++分布式实时应用框架--微服务架构的演进 上一篇:(四):C++分布式实时应用框架--状态中心模块 版权声明:本文版权及所用技术归属smartguys团队所有,对于抄袭,非经同意转载等行为保留法律 ...

  6. lms框架服务注册中心

    服务注册中心原理 在分布式系统里的注册中心.原理是将部署服务的机器地址记录到注册中心,服务消费者在有需求的时候,只需要查询注册中心,输入提供的服务名,就可以得到地址,从而发起调用. 在微服务架构下,主 ...

  7. 【转帖】阿里金融云:分布式服务注册中心(DSR)

    https://www.cloud.alipay.com/docs/middleware/register/index.html 分布式服务注册中心(DSR) 分布式服务注册中心简介 服务注册中心 ( ...

  8. silky微服务框架服务注册中心介绍

    目录 服务注册中心简介 服务元数据 主机名称(hostName) 服务列表(services) 终结点 时间戳 使用Zookeeper作为服务注册中心 使用Nacos作为服务注册中心 使用Consul ...

  9. 分布式服务注册中心XXL-REGISTRY

    <分布式服务注册中心XXL-REGISTRY> 一.简介 1.1 概述 XXL-REGISTRY 是一个轻量级分布式服务注册中心,拥有"轻量级.秒级注册上线.多环境.跨语言.跨机 ...

  10. Spring Cloud Eureka 分布式开发之服务注册中心、负载均衡、声明式服务调用实现

    介绍 本示例主要介绍 Spring Cloud 系列中的 Eureka,使你能快速上手负载均衡.声明式服务.服务注册中心等 Eureka Server Eureka 是 Netflix 的子模块,它是 ...

随机推荐

  1. NSIS使用API创建工具提示条和超级链接

    不再借助专用插件创建超级链接和工具提示条 !includensDialogs.nsh #编写:水晶石 Name "link_tooltips" OutFile "link ...

  2. POJ2686 Traveling by Stagecoach (状压DP)

    将车票的使用情况用二进制表示状态,对其进行转移即可. 但是我一开始写的代码是错误的(注释部分),看似思路是正确的,但是暗藏很大的问题. 枚举S,我们要求解的是dp[S][v],这个是从u转移过来的,不 ...

  3. uoj349【WC2018】即时战略

    题目链接 WC出了点意外滚粗了,来补补题. \(O(n^2)\)的时间复杂度,\(O(nlogn)\)的询问次数应该还是比较好想的,每次要打通到x的路径,对当前已知的树不断的找重心并询问在重心的哪颗子 ...

  4. Linux系统管理_用户管理

    cat /etc/passwd #账户文件 cat /etc/shadow #密码文件 cat /etc/login.defs #密码策略机UID定义文件 #普通用户UID范围1000~60000:系 ...

  5. Codeforces Round #830 (Div. 2) A-D

    比赛链接 A 题解 知识点:贪心,数论. 先求出序列最大公约数 \(d\) ,如果为 \(1\) 直接输出 \(0\) . 否则,尝试用最后一个数操作, \(gcd(d,n) = 1\) 则可以,花费 ...

  6. 四、docker容器管理

    一.docker容器管理 1.1 容器查看-ps命令 显示本地容器列表,但是默认不显示关闭的容器,只显示运行中的容器,除非加上命令选项 -a 用法:docker ps [-a 显示所有容器,默认只显示 ...

  7. MAUI 初体验 联合 WinForm 让家里废弃的手机当做电脑副品用起来

    软件效果图 软件架构草图 效果解释:运行 winform 端后 使用 ctrl+c 先复制任何词语,然后ctrl+空格 就可以将翻译结果显示在 安卓,IOS,windows 甚至 mac 任意客户端 ...

  8. 使用LabVIEW实现基于pytorch的DeepLabv3图像语义分割

    前言 今天我们一起来看一下如何使用LabVIEW实现语义分割. 一.什么是语义分割 图像语义分割(semantic segmentation),从字面意思上理解就是让计算机根据图像的语义来进行分割,例 ...

  9. MybatisPlus Lambda表达式 聚合查询 分组查询 COUNT SUM AVG MIN MAX GroupBy

    一.序言 众所周知,MybatisPlus在处理单表DAO操作时非常的方便.在处理多表连接连接查询也有优雅的解决方案.今天分享MybatisPlus基于Lambda表达式优雅实现聚合分组查询. 由于视 ...

  10. 【云原生 · Kubernetes】部署kube-apiserver集群

    个人名片: 因为云计算成为了监控工程师‍ 个人博客:念舒_C.ying CSDN主页️:念舒_C.ying 部署kube-apiserver集群 10.1 创建kube-apiserver 证书 10 ...