最全解决:微服务之间调用出现Load balancer does not have available server for client

问题:

背景:现在是一个服务A要调用服务B(media-api)中的方法上传文件,因此需要再服务A中写一个feignclient,里面包含的是要调用的B服务的方法,然后出现找不到目标的情况

最全解决:微服务之间调用出现Load balancer does not have available server for client_第1张图片

问题分析:

首先要确保服务和要被调用的服务都已经注册上,这里我用的是nacos。可以看到都是正常注册上来了的。

然后检查自己有没有写错对应的服务名称,看看对应的调用请求是否有错。

最全解决:微服务之间调用出现Load balancer does not have available server for client_第2张图片

然后点击在第一个出问题的地方点进去,在该方法上打个断点看看打下来的请求有没有问题,

最全解决:微服务之间调用出现Load balancer does not have available server for client_第3张图片

最全解决:微服务之间调用出现Load balancer does not have available server for client_第4张图片

在这发现uri请求应该是没有问题的,看到这的/media后面才发现是我网关没有启动 

最全解决:微服务之间调用出现Load balancer does not have available server for client_第5张图片

正常就应该打到网关,然后网关进行负载均衡的转到media-api服务 

最全解决:微服务之间调用出现Load balancer does not have available server for client_第6张图片

而media-api服务下的配置就是

最全解决:微服务之间调用出现Load balancer does not have available server for client_第7张图片

问题解决:

方案一:将服务注册上

可以试试看用eureka进行注册。nacos和erueka都是进行注册的,选择一种方案注册服务即可。

先pom配置


    org.springframework.cloud
    spring-cloud-starter-eureka

然后application上或者nacos上进行配置

ribbon:
  eureka:
​    enabled: true

方案二:取消eurka

如果你用nacos注册上,但还是报错。可以试试将eureka取消 ribbon.eureka.enabled=false;

最全解决:微服务之间调用出现Load balancer does not have available server for client_第8张图片

ribbon:
  ConnectTimeout: 60000 #连接超时时间
  ReadTimeout: 60000 #读超时时间
  MaxAutoRetries: 0 #重试次数
  MaxAutoRetriesNextServer: 1 #切换实例的重试次数
  eureka:
​    enabled: false

或者配置这个,这个就是禁用eureka然后将请求打到下面的服务提供者下,但这种写法比较固定。

大部分情况不是我们想要的

ribbon:
  eureka:
    enabled: false
## 这个IFeignService是加了@FeignClient注解的类
MediaServiceClient:
  ribbon:
    ## 服务提供者的地址,不是服务注册中心的地址
    listOfServers: http://localhost:60350

或者这个

eureka:
  client:
    register-with-eureka: false #此EurekaServer不再注册到其他注册中心
    fetch-registry: false #不再从其他注册中心拉取服务信息

方案三:检查拼写

看看自己的要调用的服务名字有没有写错,和注册上nacos的名字是否一致。

然后检查自己的请求是否有错误,请求有错也是没有办法找到该服务的。看看自己的nginx,网关等有没有打开

你可能感兴趣的:(杂谈,微服务,架构,云原生,java)