一、背景
在本地开发时常常涉及多个微服务的相互调用,多个开发的服务会同时注册到同一个eureka上。开发过程中经常需要进行断点调试,但ribbon的负载均衡策略导致服务落到其他人的机器上,无法进行本地断点调试,故开发一种优先调用本地服务,若本地不存在对应的服务则调用其他可用服务的策略。ribbon自带的客户端负载均衡策略就不在此介绍。
二、开发过程
1、新增负载均衡策略类,继承com.netflix.loadbalancer.AbstractLoadBalancerRule
2、重写choose方法,获取可以到达的servers,然后判断可达的server中是否有本地服务,若有,则返回本地server;若没有,则跳转其他server。
注意:类上面不能加@Component等注解,此类不能给spring管理。若交给spring管理,会变成默认的负载均衡策略。
3、修改配置yml文件,指定负载均衡策略类
最后启动对应的微服务注册到同一个eureka,微服务之间的相互调用优先使用本地的服务。
服务注册到eureka上,其他服务发现新注册的服务有短暂的延迟。