千家信息网

feign调用服务超时feign.RetryableException: Read timed out怎么解决

发表于:2025-02-03 作者:千家信息网编辑
千家信息网最后更新 2025年02月03日,这篇文章主要介绍"feign调用服务超时feign.RetryableException: Read timed out怎么解决",在日常操作中,相信很多人在feign调用服务超时feign.Retr
千家信息网最后更新 2025年02月03日feign调用服务超时feign.RetryableException: Read timed out怎么解决

这篇文章主要介绍"feign调用服务超时feign.RetryableException: Read timed out怎么解决",在日常操作中,相信很多人在feign调用服务超时feign.RetryableException: Read timed out怎么解决问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答"feign调用服务超时feign.RetryableException: Read timed out怎么解决"的疑惑有所帮助!接下来,请跟着小编一起来学习吧!

错误

feign.RetryableException: Read timed out

描述

feign.RetryableException: Read timed out executing POST http://cherry-pay/pay/withdraw/getFunds        at feign.FeignException.errorExecuting(FeignException.java:65)        at feign.SynchronousMethodHandler.executeAndDecode(SynchronousMethodHandler.java:105)        at feign.SynchronousMethodHandler.invoke(SynchronousMethodHandler.java:77)        at feign.ReflectiveFeign$FeignInvocationHandler.invoke(ReflectiveFeign.java:102)        at com.sun.proxy.$Proxy152.paymentToCard(Unknown Source)        at com.bjbde.trade.service.impl.WithdrawLocalServiceImpl.saveAndRequest(WithdrawLocalServiceImpl.java:62)        at com.bjbde.trade.service.impl.WithdrawLocalServiceImpl$$FastClassBySpringCGLIB$$96e64d5f.invoke()        at org.springframework.cglib.proxy.MethodProxy.invoke(MethodProxy.java:204)        at org.springframework.aop.framework.CglibAopProxy$CglibMethodInvocation.invokeJoinpoint(CglibAopProxy.java:746)        at org.springframework.aop.framework.ReflectiveMethodInvocation.proceed(ReflectiveMethodInvocation.java:163)        at org.springframework.transaction.interceptor.TransactionAspectSupport.invokeWithinTransaction(TransactionAspectSupport.java:294)        at org.springframework.transaction.interceptor.TransactionInterceptor.invoke(TransactionInterceptor.java:98)        at org.springframework.aop.framework.ReflectiveMethodInvocation.proceed(ReflectiveMethodInvocation.java:185)        at org.springframework.aop.framework.CglibAopProxy$DynamicAdvisedInterceptor.intercept(CglibAopProxy.java:688)        at com.bjbde.trade.service.impl.WithdrawLocalServiceImpl$$EnhancerBySpringCGLIB$$4633ee34.saveAndRequest()        at com.bjbde.trade.web.WithdrawController.verifyPwd(WithdrawController.java:348)        at sun.reflect.GeneratedMethodAccessor265.invoke(Unknown Source)        at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:45005)        at java.lang.reflect.Method.invoke(Method.java:498)        at org.springframework.web.method.support.InvocableHandlerMethod.doInvoke(InvocableHandlerMethod.java:209)        at org.springframework.web.method.support.InvocableHandlerMethod.invokeForRequest(InvocableHandlerMethod.java:136)        at org.springframework.web.servlet.mvc.method.annotation.ServletInvocableHandlerMethod.invokeAndHandle(ServletInvocableHandlerMethod.java:102)        at org.springframework.web.servlet.mvc.method.annotation.RequestMappingHandlerAdapter.invokeHandlerMethod(RequestMappingHandlerAdapter.java:891)        at org.springframework.web.servlet.mvc.method.annotation.RequestMappingHandlerAdapter.handleInternal(RequestMappingHandlerAdapter.java:797)        at org.springframework.web.servlet.mvc.method.AbstractHandlerMethodAdapter.handle(AbstractHandlerMethodAdapter.java:87)        at org.springframework.web.servlet.DispatcherServlet.doDispatch(DispatcherServlet.java:991)        at org.springframework.web.servlet.DispatcherServlet.doService(DispatcherServlet.java:925)        at org.springframework.web.servlet.FrameworkServlet.processRequest(FrameworkServlet.java:974)        at org.springframework.web.servlet.FrameworkServlet.doPost(FrameworkServlet.java:877)        at javax.servlet.http.HttpServlet.service(HttpServlet.java:661)        at org.springframework.web.servlet.FrameworkServlet.service(FrameworkServlet.java:851)        at javax.servlet.http.HttpServlet.service(HttpServlet.java:742)        at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:231)        at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:166)        at org.apache.tomcat.websocket.server.WsFilter.doFilter(WsFilter.java:52)        at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:193)        at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:166)        at com.alibaba.druid.support.http.WebStatFilter.doFilter(WebStatFilter.java:123)        at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:193)        at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:166)        at org.springframework.web.filter.RequestContextFilter.doFilterInternal(RequestContextFilter.java:99)        at org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:107)        at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:193)        at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:166)        at org.springframework.web.filter.HttpPutFormContentFilter.doFilterInternal(HttpPutFormContentFilter.java:109)        at org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:107)        at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:193)        at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:166)        at org.springframework.web.filter.HiddenHttpMethodFilter.doFilterInternal(HiddenHttpMethodFilter.java:93)        at org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:107)        at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:193)        at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:166)        at org.springframework.web.filter.CharacterEncodingFilter.doFilterInternal(CharacterEncodingFilter.java:200)        at org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:107)        at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:193)        at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:166)        at com.alibaba.csp.sentinel.adapter.servlet.CommonFilter.doFilter(CommonFilter.java:89)        at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:193)        at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:166)        at org.apache.catalina.core.StandardWrapperValve.invoke(StandardWrapperValve.java:198)        at org.apache.catalina.core.StandardContextValve.__invoke(StandardContextValve.java:96)        at org.apache.catalina.core.StandardContextValve.invoke(StandardContextValve.java:41002)        at org.apache.catalina.authenticator.AuthenticatorBase.invoke(AuthenticatorBase.java:493)        at org.apache.catalina.core.StandardHostValve.invoke(StandardHostValve.java:140)        at org.apache.catalina.valves.ErrorReportValve.invoke(ErrorReportValve.java:81)        at org.apache.catalina.core.StandardEngineValve.invoke(StandardEngineValve.java:87)        at org.apache.catalina.connector.CoyoteAdapter.service(CoyoteAdapter.java:342)        at org.apache.coyote.http11.Http11Processor.service(Http11Processor.java:800)        at org.apache.coyote.AbstractProcessorLight.process(AbstractProcessorLight.java:66)        at org.apache.coyote.AbstractProtocol$ConnectionHandler.process(AbstractProtocol.java:806)        at org.apache.tomcat.util.net.NioEndpoint$SocketProcessor.doRun(NioEndpoint.java:1498)        at org.apache.tomcat.util.net.SocketProcessorBase.run(SocketProcessorBase.java:49)        at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1149)        at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:624)        at org.apache.tomcat.util.threads.TaskThread$WrappingRunnable.run(TaskThread.java:61)        at java.lang.Thread.run(Thread.java:748)Caused by: java.net.SocketTimeoutException: Read timed out        at java.net.SocketInputStream.socketRead0(SocketInputStream.java)        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)        at sun.net.www.protocol.http.HttpURLConnection.getInputStream0(HttpURLConnection.java:1587)        at sun.net.www.protocol.http.HttpURLConnection.getInputStream(HttpURLConnection.java:1492)        at java.net.HttpURLConnection.getResponseCode(HttpURLConnection.java:480)        at feign.Client$Default.convertResponse(Client.java:150)        at feign.Client$Default.execute(Client.java:72)        at org.springframework.cloud.openfeign.ribbon.FeignLoadBalancer.execute(FeignLoadBalancer.java:89)        at org.springframework.cloud.openfeign.ribbon.FeignLoadBalancer.execute(FeignLoadBalancer.java:55)        at com.netflix.client.AbstractLoadBalancerAwareClient$1.call(AbstractLoadBalancerAwareClient.java:104)        at com.netflix.loadbalancer.reactive.LoadBalancerCommand$3$1.call(LoadBalancerCommand.java:303)        at com.netflix.loadbalancer.reactive.LoadBalancerCommand$3$1.call(LoadBalancerCommand.java:287)        at rx.internal.util.ScalarSynchronousObservable$3.call(ScalarSynchronousObservable.java:231)        at rx.internal.util.ScalarSynchronousObservable$3.call(ScalarSynchronousObservable.java:228)        at rx.Observable.unsafeSubscribe(Observable.java:10327)        at rx.internal.operators.OnSubscribeConcatMap$ConcatMapSubscriber.drain(OnSubscribeConcatMap.java:286)        at rx.internal.operators.OnSubscribeConcatMap$ConcatMapSubscriber.onNext(OnSubscribeConcatMap.java:144)        at com.netflix.loadbalancer.reactive.LoadBalancerCommand$1.call(LoadBalancerCommand.java:185)        at com.netflix.loadbalancer.reactive.LoadBalancerCommand$1.call(LoadBalancerCommand.java:180)        at rx.Observable.unsafeSubscribe(Observable.java:10327)        at rx.internal.operators.OnSubscribeConcatMap.call(OnSubscribeConcatMap.java:94)        at rx.internal.operators.OnSubscribeConcatMap.call(OnSubscribeConcatMap.java:42)        at rx.Observable.unsafeSubscribe(Observable.java:10327)        at rx.internal.operators.OperatorRetryWithPredicate$SourceSubscriber$1.call(OperatorRetryWithPredicate.java:127)        at rx.internal.schedulers.TrampolineScheduler$InnerCurrentThreadScheduler.enqueue(TrampolineScheduler.java:73)        at rx.internal.schedulers.TrampolineScheduler$InnerCurrentThreadScheduler.schedule(TrampolineScheduler.java:52)        at rx.internal.operators.OperatorRetryWithPredicate$SourceSubscriber.onNext(OperatorRetryWithPredicate.java:79)        at rx.internal.operators.OperatorRetryWithPredicate$SourceSubscriber.onNext(OperatorRetryWithPredicate.java:45)        at rx.internal.util.ScalarSynchronousObservable$WeakSingleProducer.request(ScalarSynchronousObservable.java:276)        at rx.Subscriber.setProducer(Subscriber.java:209)        at rx.internal.util.ScalarSynchronousObservable$JustOnSubscribe.call(ScalarSynchronousObservable.java:138)        at rx.internal.util.ScalarSynchronousObservable$JustOnSubscribe.call(ScalarSynchronousObservable.java:129)        at rx.internal.operators.OnSubscribeLift.call(OnSubscribeLift.java:48)        at rx.internal.operators.OnSubscribeLift.call(OnSubscribeLift.java:30)        at rx.internal.operators.OnSubscribeLift.call(OnSubscribeLift.java:48)        at rx.internal.operators.OnSubscribeLift.call(OnSubscribeLift.java:30)        at rx.internal.operators.OnSubscribeLift.call(OnSubscribeLift.java:48)        at rx.internal.operators.OnSubscribeLift.call(OnSubscribeLift.java:30)        at rx.Observable.subscribe(Observable.java:10423)        at rx.Observable.subscribe(Observable.java:10390)        at rx.observables.BlockingObservable.blockForSingle(BlockingObservable.java:443)        at rx.observables.BlockingObservable.single(BlockingObservable.java:340)        at com.netflix.client.AbstractLoadBalancerAwareClient.executeWithLoadBalancer(AbstractLoadBalancerAwareClient.java:112)        at org.springframework.cloud.openfeign.ribbon.LoadBalancerFeignClient.execute(LoadBalancerFeignClient.java:63)        at feign.SynchronousMethodHandler.executeAndDecode(SynchronousMethodHandler.java:98)        ... 74 more

使用场景

在Nacos作为注册中心的项目中,使用feign调用第三方接口,调用方接口报错,读数据超时。

解决方案

在调用方配置中增加一下内容

ribbon:    ReadTimeout: 60000    ConnectTimeout: 60000

拓展

根据网上查阅资料可知,在Spring Cloud架构下,出现此类问题的解决方案同上述解决方案一致。

到此,关于"feign调用服务超时feign.RetryableException: Read timed out怎么解决"的学习就结束了,希望能够解决大家的疑惑。理论与实践的搭配能更好的帮助大家学习,快去试试吧!若想继续学习更多相关知识,请继续关注网站,小编会继续努力为大家带来更多实用的文章!

0