1、首先我们都知道Eureka中进行服务的消费有三种方式

1、DiscoveryClient:通过元数据获取服务信息
2、LoadBalancerClinet:Ribbon负载均衡器
3、@LoadBalanced:通过注解开启Ribbon的负载均衡器

2、出现以上的错误的原因是有五种可能情况



第一种

当你使用LoadBalancerClient方式时,没有去掉@LoadBalanced注解;导致两种方式冲突。

以下为错误实例

@Configuration
public class ConsumerConfig {
@Bean
@LoadBalanced
public RestTemplate getRestTemplate() {
return new RestTemplate();
}
}
public List<Product> getProductListByLoadBalancerClient() {
StringBuffer sb = null;
ServiceInstance instance = loadBalancerClient.choose("service-provider");
if (instance == null) {
return null;
}
sb = new StringBuffer();
sb.append("http://"+instance.getHost()+":"+instance.getPort()+"/product/list");
ResponseEntity<List<Product>> exchange = restTemplate.exchange(sb.toString(), HttpMethod.GET, null, new ParameterizedTypeReference<List<Product>>() {
});
return exchange.getBody();
}

解决方法:单独使用其中一种方式,不要都码上去




第二种

使用@LoadBalanced注解方式时,需要这个类需要我们通过@Bean注入加上@LoadBanlance
将下面的代码加入到启动类或者Configuration类中,将其注入到容器中。

@Configuration
public class ConsumerConfig {
@Bean
@LoadBalanced
public RestTemplate getRestTemplate() {
return new RestTemplate();
}
}

解决方法:如上面代码所示




第三种

导入了两个依赖spring-cloud-starter-netflix-eureka-client 和 spring-cloud-starter-netflix-ribbon造成冲突
因为spring-cloud-starter-netflix-eureka-client 已经默认集成了 spring-cloud-starter-netflix-ribbon

演示错误做法:

<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-starter-netflix-eureka-client</artifactId>
</dependency>
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-netflix-ribbon</artifactId>
<version>2.1.4.RELEASE</version>
</dependency>

解决方法:去掉spring-cloud-netflix-ribbon依赖即可




第四种

服务直接的调用,如果要使用服务名进行调用,应该使用下面这个spring.application.name的值进行访问

Eureka出现No instances available for xxx的五种解决方案(不能解决你骂我)_spring


Eureka出现No instances available for xxx的五种解决方案(不能解决你骂我)_解决方法_02




第五种

错误原因是没有进行服务发现,导致使用RestTemplate的时候始终找不到服务地址。
解决方式就是在服务提供者的启动类上加上@EnableDiscoveryClient注解然后重启服务提供者,目的就是让这个服务能够被发现,也就是消费者使用RestTemplate去调用服务提供者的时候,去注册中心找这个服务。