LoadBalancer如何自定义负载均衡

LoadBalancer自带的负载均衡算法只有两种,分别是轮询(对应的实现类是org.springframework.cloud.loadbalancer.core.RoundRobinLoadBalancer)和随机(对应的实现类是org.springframework.cloud.loadbalancer.core.RandomLoadBalancer),默认用的是轮询,其定义点在配置类LoadBalancerClientConfiguration中:
在这里插入图片描述
我们可以自定义负载均衡实现,方法如下:
1、自定义负载均衡类,并实现org.springframework.cloud.loadbalancer.core.ReactorServiceInstanceLoadBalancer接口,并重写choose方法,该方法的主要作用就是从某个服务的多个ServiceInstance中选出一个服务实例,该实例会用于后续的服务调用:

package com.ljc.conf;

import org.springframework.beans.factory.ObjectProvider;
import org.springframework.cloud.client.ServiceInstance;
import org.springframework.cloud.client.loadbalancer.DefaultResponse;
import org.springframework.cloud.client.loadbalancer.EmptyResponse;
import org.springframework.cloud.client.loadbalancer.Request;
import org.springframework.cloud.client.loadbalancer.Response;
import org.springframework.cloud.loadbalancer.core.NoopServiceInstanceListSupplier
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值