Ribbon 負(fù)載均衡

core:Java功能增強 —— 攔截器

通過@LoadBalanced修飾就可以為應(yīng)用引入Ribbon框架來實現(xiàn)負(fù)載均衡。

 @Configuration
public class ConfigBean {

/**
 * 使用@LoadBalanced開啟負(fù)載均衡
 * RestTemplate 通過它來訪問服務(wù)
 * */
@LoadBalanced
@Bean
RestTemplate restTemplate() {
    return new RestTemplate();
}
}

使用時這樣(jServer1就是注冊在eureka的服務(wù)名):

@RestController
@RequestMapping("/")
public class HelloController {
@Autowired
RestTemplate restTemplate;

@RequestMapping("/hello")
public String hello() {
    String result = restTemplate.getForEntity("http://jServer1/hello",String.class).getBody();
    System.out.println(result);
    return result;
}
}

所以Ribbon的核心在于@LoadBalanced,那它引入了哪些東西呢?進(jìn)入看一下:


image.png

立刻明白了什么,是老朋友攔截器啊,所以是攔截了請求,然后根據(jù)負(fù)載均衡策略找到合適的服務(wù)實例,再發(fā)請求出去么。

intercept方法如下:

public ClientHttpResponse intercept(final HttpRequest request, final byte[] body, final ClientHttpRequestExecution execution) throws IOException {
    URI originalUri = request.getURI();
    String serviceName = originalUri.getHost();
    return (ClientHttpResponse)this.loadBalancer.execute(serviceName, new LoadBalancerRequest<ClientHttpResponse>() {
        public ClientHttpResponse apply(ServiceInstance instance) throws Exception {
            HttpRequest serviceRequest = LoadBalancerInterceptor.this.new ServiceRequestWrapper(request, instance);
            return execution.execute(serviceRequest, body);
        }
    });
}

進(jìn)到execute方法:

public <T> T execute(String serviceId, LoadBalancerRequest<T> request) throws IOException {
    ILoadBalancer loadBalancer = this.getLoadBalancer(serviceId);

    //就是這里了?。?    Server server = this.getServer(loadBalancer);

    if (server == null) {
        throw new IllegalStateException("No instances available for " + serviceId);
    } else {
        RibbonLoadBalancerClient.RibbonServer ribbonServer = new RibbonLoadBalancerClient.RibbonServer(serviceId, server, this.isSecure(server, serviceId), this.serverIntrospector(serviceId).getMetadata(server));
        RibbonLoadBalancerContext context = this.clientFactory.getLoadBalancerContext(serviceId);
        RibbonStatsRecorder statsRecorder = new RibbonStatsRecorder(context, server);

        try {
            T returnVal = request.apply(ribbonServer);
            statsRecorder.recordStats(returnVal);
            return returnVal;
        } catch (IOException var9) {
            statsRecorder.recordStats(var9);
            throw var9;
        } catch (Exception var10) {
            statsRecorder.recordStats(var10);
            ReflectionUtils.rethrowRuntimeException(var10);
            return null;
        }
    }
}

 protected Server getServer(ILoadBalancer loadBalancer) {
    return loadBalancer == null ? null : loadBalancer.chooseServer("default");
}

以最基本的BaseLoadBalancer為例(還有其他Balancer實現(xiàn)):

public Server chooseServer(Object key) {
    if (this.counter == null) {
        this.counter = this.createCounter();
    }

    this.counter.increment();
    if (this.rule == null) {
        return null;
    } else {
        try {
            //這里的rule = DEFAULT_RULE = new RoundRobinRule();
            return this.rule.choose(key);
        } catch (Throwable var3) {
            return null;
        }
    }
}

可以發(fā)現(xiàn)是根據(jù)IRule.choose(key)來選擇服務(wù)器實例的,而IRule就是負(fù)載均衡策略接口,可以看出已經(jīng)默認(rèn)實現(xiàn)了很多種策略:


image.png
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時請結(jié)合常識與多方信息審慎甄別。
平臺聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點,簡書系信息發(fā)布平臺,僅提供信息存儲服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

  • Spring Cloud為開發(fā)人員提供了快速構(gòu)建分布式系統(tǒng)中一些常見模式的工具(例如配置管理,服務(wù)發(fā)現(xiàn),斷路器,智...
    卡卡羅2017閱讀 136,551評論 19 139
  • balancer:均衡器 如果是自己寫一個負(fù)載均衡器思路應(yīng)該是什么?參考nginx,部署多個服務(wù),形成一對多的關(guān)系...
    Chinesszz閱讀 1,138評論 0 2
  • 斷斷續(xù)續(xù)看Ribbon的源碼差不多也有7-8天了,總算告一段落。本文記錄了這些天對源碼的閱讀過程與一些分析理解,如...
    程序猿DD閱讀 6,680評論 6 11
  • 先從Ribbon的自動配置看,LoadBalancerAutoConfiguration。 ribbonInter...
    wonfi_admin閱讀 798評論 0 0
  • 我想抽卡,看看我為什么總想要得到他人的認(rèn)可,可以嗎 可以探索原因,也可以看看求認(rèn)可前和得到認(rèn)可時,沒有得到...
    深海觀魚閱讀 208評論 0 0

友情鏈接更多精彩內(nèi)容