Ribbon实现客户端负载均衡

概述:Ribbon是客户端负载均衡器,一般搭配Eureka一起使用(是同一家产品)

坐标:https://mvnrepository.com/artifact/com.netflix.ribbon/ribbon/2.7.18

Ribbon的在微服务中的位置:

 2 ribbon做微服务远程调用简化开发(其实就是 @LoadBalanced 注解的添加):

@Configuration
public class RestTemplateConfig {
    /*
     * 注入远程调用
     * */
    @LoadBalanced //ribbon注解:添加这个注解以后可以通过服务名字掉进行地址的绑定
    @Bean
    public RestTemplate restTemplate(){
        return new RestTemplate();
    }
}

controller类:

2 ribbon做微服务远程调用端负载均衡(客户端负载均衡)

ribbon的负载均衡策略 

实现:

编码形式:

均衡策略(若是使用也是我们实现IRule接口自己定义的规则)

@Configuration
public class RibbonRuleConfig {
    @Bean
    public IRule iRule(){
        //或者是自己实现IRule接口的类
        return new RandomRule();
    }
}

引导类开启支持:



@SpringBootApplication
@EnableEurekaClient
@EnableDiscoveryClient
//开启自己定义的负载均衡,指明针对哪个服务员实行这个负载均衡策略,注册中心可能有很多个服务,同时指明规则配置类
@RibbonClient(name = "服务提供方的名字",configuration = RibbonRuleConfig.class)
public class EurekaConsumer {

    public static void main(String[] args) {
        SpringApplication.run(EurekaConsumer.class,args);

    }
}

配置文件形式: 

EUREKA-PROVIDER:  # 生产者的名称(服务名称)

 ribbon:

NFLoadBalancerRuleClassName:  com.netflix.loadbalancer.RandomRule  # 负载均衡策略全类名

基本上就是这个样子!!!!!! 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值