Ribbon
Ribbon 是一个基于 HTTP 和 TCP 客户端的负载均衡器它可以在客户端配置 ribbonServerList(服务端列表),然后轮询请求以实现均衡负载它在联合 Eureka 使用时ribbonServerList 会被 DiscoveryEnabledNIWSServerList 重写,扩展成从 Eureka 注册中心获取服务端列表同时它也会用 NIWSDiscoveryPing 来取代 IPing,它将职责委托给 Eureka 来确定服务端是否已经启动。
Feign
注意:spring-cloud-starter-feign 里面已经包含了 spring-cloud-starter-ribbon(Feign 中也使用了 Ribbon)
ribbon和feign两个的区别和选择
-
选择feign
-
默认集成了ribbon
-
写起来更加思路清晰和方便
-
采用注解方式进行配置,配置熔断等方式方便
-
-
在product-service类中,加入
try { TimeUnit.SECONDS.sleep(2); } catch (InterruptedException e) { e.printStackTrace(); }
会出现这个情况:
原因:默认optons readtimeout是60,但是由于hystrix默认是1秒超时。
解决方法:
#修改调用超时时间
#ribbon的超时时间
ribbon