两个错误,
- 错误一:
com.netflix.zuul.exception.ZuulException: Forwarding error
Caused by: java.lang.RuntimeException: java.net.SocketTimeoutException: Read timed out
at rx.exceptions.Exceptions.propagate(Exceptions.java:58) ~[rxjava-1.1.10.jar:1.1.10]
at rx.observables.BlockingObservable.blockForSingle(BlockingObservable.java:465) ~[rxjava-1.1.10.jar:1.1.10]
at rx.observables.BlockingObservable.single(BlockingObservable.java:342) ~[rxjava-1.1.10.jar:1.1.10]
at com.netflix.client.AbstractLoadBalancerAwareClient.executeWithLoadBalancer(AbstractLoadBalancerAwareClient.java:117) ~[ribbon-loadbalancer-2.2.2.jar:2.2.2]
... 132 common frames omitted
Caused by: java.net.SocketTimeoutException: Read timed out
- 错误二:
com.netflix.zuul.exception.ZuulException: Forwarding error
Caused by: com.netflix.client.ClientException: Load balancer does not have available [Consul服务上的已经注册成功的服务名]
断路器问题/ribbon问题,加了配置:
zuul:
host:
connect-timeout-millis: 3000
socket-timeout-millis: 60000
# 添加ribbon的超时时间设置
ribbon:
ReadTimeout: 60000
ConnectTimeout: 60000
hystrix:
command:
default:
execution:
isolation:
thread:
timeoutInMilliseconds: 60000
我这里报的是错误二:
解决方案是
spring.cloud.consul.ribbon.enabled=false
# 示例:hello-world.ribbon.listOfServers=192.168.26.183:8777
{替换成需要调用的服务名}.ribbon.listOfServers={替换成需要调用服务的IP:端口号}
大部分网上的解决方法是eureka的解决方法:
再次查询,成功。