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

    一、背景

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

 

二、开发过程

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

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

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

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

 

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

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

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值