负载均衡流程
IRule决定负载均衡策略
默认ZoneAvoidanceRule。
调整负载均衡规则
通过定义IRule实现可以修改负载均衡规则,有两种方式:
1、代码方式:【全局作用在orderservice无论调用哪一个服务都是用该种负载均衡方式】在order-service中的OrderApplication类中,定义一个新的IRule:
package cn.itcast.order; import com.netflix.loadbalancer.IRule; import com.netflix.loadbalancer.RandomRule; import org.mybatis.spring.annotation.MapperScan; import org.springframework.boot.SpringApplication; import org.springframework.boot.autoconfigure.SpringBootApplication; import org.springframework.cloud.client.loadbalancer.LoadBalanced; import org.springframework.context.annotation.Bean; import org.springframework.web.client.RestTemplate; @MapperScan("cn.itcast.order.mapper") @SpringBootApplication public class OrderApplication { public static void main(String[] args) { SpringApplication.run(OrderApplication.class, args); } /** * 创建RestTemplate并注入spring容器 * @return */ @Bean @LoadBalanced public RestTemplate restTemplate(){ return new RestTemplate(); } @Bean public IRule randomRule(){ return new RandomRule(); } }
2、配置文件方式:在order-service的application.yml文件中,添加新的配置也可以修改规则:
【指定某个微服务的负载均衡策略】如指定userseivice的负载均衡策略
标签:负载,springframework,IRule,均衡,org,import,Ribbon From: https://www.cnblogs.com/fxzm/p/17493042.html