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