您好,登錄后才能下訂單哦!
今天就跟大家聊聊有關Ribbon中怎么使用LoadBalancerRule實現負載均衡,可能很多人都不太了解,為了讓大家更加了解,小編給大家總結了以下內容,希望大家根據這篇文章可以有所收獲。
Ribbon的版本是2.3.0.release.
這些復雜均衡實現類都實現了com.netflix.loadbalancer.IRule接口,zuul中提供了好幾種實現類:
AvailabilityFilteringRule
BestAvailableRule
RandomRule
RetryRule
RoundRobinRule
WeightedResponseTimeRule
ZoneAvoidanceRule
AbstractLoadBalancerRule如下List-1:
List-1
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接口
public interface IRule { Server choose(Object var1); void setLoadBalancer(ILoadBalancer var1); ILoadBalancer getLoadBalancer(); }
List-2中,choose方法就是選取服務的接口,不同的實現類內部選取算法不同。
看完上述內容,你們對Ribbon中怎么使用LoadBalancerRule實現負載均衡有進一步的了解嗎?如果還想了解更多知識或者相關內容,請關注億速云行業資訊頻道,感謝大家的支持。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。