前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >Ribbon的LoadBalancerRule复杂均衡实现 原

Ribbon的LoadBalancerRule复杂均衡实现 原

作者头像
克虏伯
发布2019-10-06 20:58:10
6750
发布2019-10-06 20:58:10
举报

   Ribbon的版本是2.3.0.release.

    这些复杂均衡实现类都实现了com.netflix.loadbalancer.IRule接口,zuul中提供了好几种实现类:

  • AvailabilityFilteringRule 
  • BestAvailableRule
  • RandomRule
  • RetryRule
  • RoundRobinRule
  • WeightedResponseTimeRule
  • ZoneAvoidanceRule

    AbstractLoadBalancerRule如下List-1:

List-1

代码语言:javascript
复制
public abstract class AbstractLoadBalancerRule implements IRule, IClientConfigAware {
    private ILoadBalancer lb;

    public AbstractLoadBalancerRule() {
    }

    public void setLoadBalancer(ILoadBalancer lb) {
        this.lb = lb;
    }

    public ILoadBalancer getLoadBalancer() {
        return this.lb;
    }
}

    如上List-1所示,ILoadBalancer提供获取服务列表的功能。

List-2 IRule接口

代码语言:javascript
复制
public interface IRule {
    Server choose(Object var1);

    void setLoadBalancer(ILoadBalancer var1);

    ILoadBalancer getLoadBalancer();
}

    List-2中,choose方法就是选取服务的接口,不同的实现类内部选取算法不同。

Reference

  1. https://github.com/Netflix/ribbon/tree/v2.3.0

(adsbygoogle = window.adsbygoogle || []).push({});

本文参与 腾讯云自媒体分享计划,分享自作者个人站点/博客。
如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • Reference
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档