一、背景

       在本地开发时常常涉及多个微服务的相互调用,多个开发的服务会同时注册到同一个eureka上。开发过程中经常需要进行断点调试,但ribbon的负载均衡策略导致服务落到其他人的机器上,无法进行本地断点调试,故开发一种优先调用本地服务,若本地不存在对应的服务则调用其他可用服务的策略。ribbon自带的客户端负载均衡策略就不在此介绍。

 

二、开发过程

     1、新增负载均衡策略类,继承com.netflix.loadbalancer.AbstractLoadBalancerRule

     2、重写choose方法,获取可以到达的servers,然后判断可达的server中是否有本地服务,若有,则返回本地server;若没有,则跳转其他server。

自定义开发环境SpringCloudRibbon客户端负载均衡策略

注意:类上面不能加@Component等注解,此类不能给spring管理。若交给spring管理,会变成默认的负载均衡策略。

3、修改配置yml文件,指定负载均衡策略类

自定义开发环境SpringCloudRibbon客户端负载均衡策略

 

最后启动对应的微服务注册到同一个eureka,微服务之间的相互调用优先使用本地的服务。

服务注册到eureka上,其他服务发现新注册的服务有短暂的延迟。

相关文章:

  • 2022-12-23
  • 2022-12-23
  • 2021-12-14
  • 2021-10-04
  • 2021-06-25
  • 2021-10-09
  • 2022-12-23
  • 2021-07-09
猜你喜欢
  • 2021-09-11
  • 2021-06-21
  • 2021-09-10
  • 2021-10-24
  • 2021-12-14
  • 2021-09-08
  • 2021-06-24
相关资源
相似解决方案