欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页

Ribbon的饥饿加载(eager-load)模式及服务调用超时配置

程序员文章站 2022-05-24 14:35:57
...

前言

今天在使用微服务调用时服务之间调用超时,报错如下:

feign.RetryableException: Read timed out executing POST http://******

也可能会有人在服务都成功启动的时候第一次访问会有报错的情况发生,但是之后又恢复正常访问。

解决办法:

首先第一次调用失败后面正常:要解决此问题那么让需要实例化的类提前创建,而不是在第一次调用的时候创建。

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

#预加载配置,默认为懒加载
ribbon:
  eager-load:
    enabled: true
    clients: zoo-plus-email

zoo-plus-email:
  ribbon:
    ReadTimeout: 3000
    ConnectTimeout: 3000

参数说明:

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

ribbon.eager-load.clients: 指定需要饥饿加载的服务名

后面是对单个服务配置连接读取时间。

配置ribbon可以全部服务配置:

ribbon:
  ReadTimeout: 15000
  ConnectTimeout: 60000