Ribbon负载均衡

负载均衡流程

 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的负载均衡策略

 

   

posted @ 2023-06-20 10:56  佛系粥米  阅读(21)  评论(0)    收藏  举报