从0到1实现RPC | 04 负载均衡和静态注册中心

一、Router的定义

Router路由用于预筛选,Dubbo有这样的设计,SpringCloud没有。

二、LoadBanlancer定义

负载均衡器:默认取第一个

当前支持随机和轮询两种负载均衡器。

随机:从所有provider中随机选择一个。

轮询:每个provider服务按照顺序,依次调用

三、注册中心的定义

  1. 开始方法start();
  2. 停止方法stop();
  3. Provider的注册方法register();
  4. Provider的取消注册方法unregister();
  5. Consumer的获取所有服务方法fetchAll();
  6. 默认提供的静态注册中心类型,是为了后续的动态注册中心做准备。都是空方法,只是fetchAll()默认返回了所有providers;

四、RpcContext定义

RpcContext用于封装上下文参数,避免参数过多传递。当前有过滤器Filter,负载均衡器LoadBalancer、路由器Router。

五、创建Bean

在消费者配置类ConsumerConfig中创建Bean,包括注册中心,路由器和负载均衡器(这里使用的是轮询)。

六、封装代理类

在消费者启动类ConsumerBootstrap中, 把路由器router和负载均衡器loadBalancer封装到RpcContext中。

在创建代理对象时,通过注册中心获取到所有的服务提供者providers,然后联合上下文信息RpcContext一起传递给代理类。

在代理类中完成负载均衡,确定调用的服务类。

七、测试

启动三个服务提供者provider,端口分别是8081,8082,8083

启动服务消费者Consumer,配置好服务提供者provider的地址。

同一个接口连续调用三次,可以看到返回结果,依次访问的是8081,8082,8083这三个服务,使用轮询负载均衡的目的已经成功了。

工程地址:

https://github.com/midnight2104/midnight-rpc/tree/lesson4

相关推荐
编程修仙9 分钟前
第一篇 认识SpringBoot
java·spring boot
骇客野人13 分钟前
.gitignore文件常用设置
java
bill44721 分钟前
BPMN2.0,flowable工作流,【用户任务】使用【任务监听器】动态设置下一步处理人
java·工作流引擎·flowable·bpmn
Cricyta Sevina22 分钟前
Java 语言多线程核心概念全解析
java·开发语言
shenzhenNBA30 分钟前
如何在python文件中使用日志功能?简单版本
java·前端·python·日志·log
遇印记1 小时前
javaOCA考点(基础)
java·开发语言·青少年编程
阿里云云原生1 小时前
告别“看不见的内存”!SysOM 如何实现 Java 进程内存全景分析?
java·云原生
Andy工程师1 小时前
Spring Boot 按照以下顺序加载配置(后面的会覆盖前面的):
java·spring boot·后端