Spring Cloud Ribbon源码分析

Spring Cloud Netflix Ribbon 负载均衡详解

一、ILoadBalancer

Ribbon实现负载均衡的核心接口为ILoadBalancer

public interface ILoadBalancer {
   //添加后端服务
  public void addServers(List<Server> newServers);

  //选择一个后端服务
  public Server chooseServer(Object key); 

//标记一个服务不可用
  public void markServerDown(Server server);

//获取当前可用的服务列表
  public List<Server> getReachableServers();

//获取所有后端服务列表
   public List<Server> getAllServers();
}

ILoadBalancer 接口的类层结构如下所示:

 核心功能实现在BaseLoadBalancer类中,核心组件有IRule、IPing和LoadBalancerStats等。

1. IRule

IRule 接口是对负载均衡策略的一种抽象,可以通过实现这个接口来提供各种适用的负载均衡算法

public interface IRule{
    public Server choose(Object key);

    public void setLoadBalancer(ILoadBalancer lb);
    public ILoadBalancer getLoadBalancer();
}

choose 方法是该接口的核心方法,根据key从指定服务列表中获取对应的服务

2. IPing

IPing 接口判断目标服务是否存活,定义如下:

public interface IPing {
    public boolean isAlive(Server server);
}

        可以看到 IPing 接口中只有一个 isAlive() 方法,通过对服务发出"Ping"操作来获取服务响应,从而判断该服务是否可用。

3.  LoadBalancerStats    

        

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值