feign.RetryableException: Read timed out executing 异常解决办法

2022-08-03 09:46:46

首先看一下报错整体:

feign.RetryableException: Read timed out executing GET (你访问的地址)

	at feign.FeignException.errorExecuting(FeignException.java:67)
	at feign.SynchronousMethodHandler.executeAndDecode(SynchronousMethodHandler.java:104)
	at feign.SynchronousMethodHandler.invoke(SynchronousMethodHandler.java:76)
	at feign.ReflectiveFeign$FeignInvocationHandler.invoke(ReflectiveFeign.java:103)
	at com.sun.proxy.$Proxy100.querySpuByPage(Unknown Source)
Caused by: java.net.SocketTimeoutException: Read timed out
	at java.net.SocketInputStream.socketRead0(Native Method)
	at java.net.SocketInputStream.socketRead(SocketInputStream.java:116)
	at java.net.SocketInputStream.read(SocketInputStream.java:171)
	at java.net.SocketInputStream.read(SocketInputStream.java:141)
	at java.io.BufferedInputStream.fill(BufferedInputStream.java:246)
	at java.io.BufferedInputStream.read1(BufferedInputStream.java:286)
	at java.io.BufferedInputStream.read(BufferedInputStream.java:345)
	at sun.net.www.http.HttpClient.parseHTTPHeader(HttpClient.java:735)
	at sun.net.www.http.HttpClient.parseHTTP(HttpClient.java:678)

分析原因:

报错误的原因是feign访问超时,导致错误的原因是Ribbon设置的连接超时时间或数据的读取超时时间设置的太短,或者使用了默认的超时时间。

解决办法:

把Ribbon的连接超时和数据读取超时时间改的稍微长一些。

ribbon:
  ConnectTimeout: 10000 # ribbon链接超时时长
  ReadTimeout: 10000 # ribbon读取超时时间长

补充:

出现这个问题原因可能有很多种,例如:1. 就是服务器反应慢,超出了ribbon的连接时常。2. 配置了redis,但是redis未启动。

当修改完ribbon还是不能解决问题的时候,看看其他微服务有没有报错。

  • 作者:qq_865326685
  • 原文链接:https://blog.csdn.net/a1004314120/article/details/90321022
    更新时间:2022-08-03 09:46:46