首先看一下报错整体:
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还是不能解决问题的时候,看看其他微服务有没有报错。