源码探究
@LoadBalanced注解只是开启负载均衡功能,而负载均衡的核心实现类是IRule。
package com.netflix.loadbalancer;
public interface IRule {
Server choose(Object var1);
//设置实现负载均衡的方式
void setLoadBalancer(ILoadBalancer var1);
ILoadBalancer getLoadBalancer();
}
IRule实现类:代表了不同的负载均衡方式
RoundRobinRule 轮询策略
RandomRule 随机策略
AvailabilityFilteringRule : 会先过滤掉,跳闸,访问故障的服务~,对剩下的进行轮询~
RetryRule : 会先按照轮询获取服务~,如果服务获取失败,则会在指定的时间内进行,重试
其它策略实现负载均衡
轮询策略是默认的策略,只需要加上@LoadBalanced注解就可以实现了。其它策略需要我们再进行一些配置
config
package com.dong.consumer.config;
import com.netflix.loadbalancer.IRule;
@Configuration
//@Configuration ... 相当于spring中的配置文件 applicationContext.xml文件
public class ConfigBean {
@Bean
@LoadBalanced //配置负载均衡实现RestTemplate
public RestTemplate getRestTemplate() {
return new RestTemplate();
}
@Bean
public IRule myRule(){
return new RandomRule();
}
}
此时我们再从consumer模块访问provider:如访问接口http://localhost/consumer/dept/get/1 。我们发现访问的数据库是随机的没有规律的。[上面的配置就从默认的轮询策略到了随机策略实现负载均衡了]
自定义负载均衡策略
从官方文档我们可以看到自定义的的负载均衡策略类不能在主启动类的扫描包下,如我的程序定义的包结构如下:
config 注意包的路径
package com.dong.myrule;
import com.netflix.loadbalancer.IRule;
@Configuration
public class MyRules {
@Bean
public IRule myRule(){
return new RandomRule();
}
}
//这里我只是想演示自定义策略的定义思路,我还是return new RandomRule();使用的随机策略。
//我们可以自定义一个类模仿随机策略,然后return new myRandomRule()就实现自定义了。(详细步骤略)
主启动类 使用自定义的方式我们需要使用@RibbonClient注解
package com.dong.consumer;
import com.dong.myrule.MyRules;
@SpringBootApplication
@EnableEurekaClient
//在微服务启动的时候就能加载自定义的负载均衡策略
//name表示consumer负载均衡调用的服务注册到Eureka的名称
//configuration 表示自定从策略的配置类
@RibbonClient(name = "SPRINGCLOUD-PROVIDER-DEPT",configuration = MyRules.class)
public class ConsumerApplication {
public static void main(String[] args) {
SpringApplication.run(ConsumerApplication.class, args);
}
}
然后访问:http://localhost/consumer/dept/get/1 结果也是随机访问了不同的provider服务
参考教程:https://www.kuangstudy.com/
原文:https://www.cnblogs.com/lanxinren/p/14792795.html