新闻资讯

新闻资讯 行业动态

Spring Cloud:Ribbon的饥饿加载(eager-load)模式

编辑:008     时间:2020-02-28

问题原因

造成第一次服务调用出现失败的原因主要是Ribbon进行客户端负载均衡的Client并不是在服务启动的时候就初始化好的,而是在调用的时候才会去创建相应的Client,所以第一次调用的耗时不仅仅包含发送HTTP请求的时间,还包含了创建RibbonClient的时间,这样一来如果创建时间速度较慢,同时设置的超时时间又比较短的话,很容易就会出现上面所描述的显现。

从日志中我们也能知道这一点细节,在第一次发起调用的时候我们可以从日志中看到如下信息:

  1. 2017-09-2508:29:54,201INFO  [main]com.netflix.loadbalancer.DynamicServerListLoadBalancer-DynamicServerListLoadBalancerforclient hello-service initialized:DynamicServerListLoadBalancer:{NFLoadBalancer:name=hello-service,current list ofServers=[192.168.99.176:9901],Loadbalancer stats=Zonestats:{unknown=[Zone:unknown;   Instancecount:1; Activeconnections count:0;   Circuitbreaker tripped count:0; Activeconnections per server:0.0;]

  2. },Serverstats:[[Server:192.168.99.176:9901;   Zone:UNKNOWN; TotalRequests:0; Successiveconnection failure:0;   Totalblackout seconds:0; Lastconnection made:ThuJan0108:00:00CST1970; Firstconnection made:ThuJan0108:00:00CST1970;   ActiveConnections:0;  total failure countinlast(1000)msecs:0;average resp time:0.0; 90percentile resp time:0.0;   95percentile resp time:0.0;   min resp time:0.0; max resp time:0.0; stddev resp time:0.0]

  3. ]}ServerList:ConsulServerList{serviceId='hello-service',tag=null}

而Feign的实现基于Ribbon,所以它也有一样的问题,下面就来看看如何解决这个问题。

解决方法

解决的方法很简单,既然第一次调用时候产生RibbonClient耗时,那么就让它提前创建,而不是在第一次调用的时候创建。

在Spring Cloud的Dlaston版本中提供了几个新的参数,它们可以很方便的帮我们实现这样的功能。

  1. ribbon.eager-load.enabled=true

  2. ribbon.eager-load.clients=hello-service,user-service

参数说明:

  • ribbon.eager-load.enabled:开启Ribbon的饥饿加载模式

  • ribbon.eager-load.clients:指定需要饥饿加载的客户端名称、服务名

通过上面的配置完成之后,我们尝试重启一下服务消费者,这个时候我们会发现,我们没有开始调用服务接口,但是上面初始化负载均衡的日志就已经打印出来了。这就说明我们对ribbon的饥饿加载模块设置已经生效了。


原文链接:https://mp.weixin.qq.com/s/-KISrvtBd0NNQ3dmTsRI_Q

郑重声明:本文版权归原作者所有,转载文章仅为传播更多信息之目的,如作者信息标记有误,请第一时间联系我们修改或删除,多谢。

回复列表

相关推荐