文章图片
搭建了springcloud服务如上图;eureka 集群两台、CONSUME-SERVICE 有两台 、USER有两台
现在在USER服务里面需要调用CONSUME-SERVICE的服务;代码如下
/**
* Created by li.ma on 2020/6/8.
*/
@FeignClient(name = "CONSUME-SERVICE" )
public interface HelloFeignService {
//地址为服务提供者对外暴露的地址
@RequestMapping(value = "https://www.it610.com/TestProvider/hello11" , method = RequestMethod.GET)
String hello(@RequestParam("uid") String uid);
}
但是后台定制了路由策略
@Bean
public IRule getIReule(){ //通过获取一个IRule对象,
System.err.println("getIReule ---------------------------------------------------");
returnnew RandomRule();
//达到的目的,用我们重新选择的随机,替代默认的轮训方式
}
当定义了这个类之后,会出现
RandomRule 父类 AbstractLoadBalancerRule父类的属性 private ILoadBalancer lb;
此属性的子属性allServerList 为空列表;导致服务之间的调用无法拿到负载均衡的服务列表
自定义了RandomRule之后就会实例化多个RandomRule对象,有的RandomRule对象里面的负载的allServerList是空列表;导致无法访问
【springcloud 服务调用成功几次之后都会失败】如果正常的时候,会定义各种不同的Rule(RoundRobinRule、ZoneAvoidanceRule等等)
推荐阅读
- SpringCloud浅尝(六)——Bus
- SpringCloud浅尝(三)——Eureka
- SpringCloud浅尝(十)——Sleuth ZipKin
- SpringCloud浅尝(九)——Hystrix Dashboard
- SpringCloud浅尝(八)——Hystrix
- SpringCloud(三)多节点高可用Eureka注册中心集群
- springcloud搭建eureka服务
- SpringCloud之 Eureka 的服务治理
- 搭建微服务(服务提供者与服务消费者)