springcloud学习 第三章:负载均衡器ribbon

下载源码:https://gitee.com/ctocloud/spring-cloud-poetry.git

1、定义
            Ribbon 做为负载均衡器首先会从注册中心获取可用的服务实例,然后会通过负载均衡机制为服务消费者选择调用哪一个服务实例,从而达到缓解网络压力和扩容的目的。同时也具备容灾的作用,不会应为莫一台实例故障而导致系统不可用。负载均衡策略常见的有轮询负载,权重负载,按流量负载,同时Ribbon也支持自定义负载策略。

2、负载策略
    ️RandomRule:随机策略会通过一个随机数从可用服务实例中选择一个实例。实现是用一个while循环,如果实例为空则执行随机选择,直到获取到。该策略有不严谨的地方,如果一直获取不到,很可能出现死循环的情况。


    ️RoundRobinRule:按照线性轮训的方式选择可用的实例。该策略定义了一个计数器的变量,每次循环后计数器累加    ,如果10次选择不到服务实例,则提示无可用服务。


    ️RetryRule:该策略增加了重试的机制,默认使用RoundRobinRule策略,如果超过时间阙值则返回null。


    ️WeightedResponseTimeRule:是在RoundRobinRule的基础上增加权重的策略,会根据实例的响应以及运行情况分配负载的权重,以便更好的利用资源,达到最优化。


    ️BestAvailableRule:遍历所有可用实例,过滤到故障实例,选择出请求并发数最小的一个。也就是说会优先选择空闲实例。

 

新建:cloud-consumer

        <dependency>
            <groupId>org.springframework.cloud</groupId>
            <artifactId>spring-cloud-starter-netflix-ribbon</artifactId>
        </dependency>

配置文件: 

eureka:
  client:
    serviceUrl:
      defaultZone: http://localhost:8081/eureka/
server:
  port: 8083
spring:
  application:
    name: cloud-consumer

 


启动文件,注入RestTemplate服务调用模板:


@SpringBootApplication
@EnableEurekaClient
@EnableDiscoveryClient
@EnableHystrix
public class ConsumerApplication {

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

    @Bean
    @LoadBalanced
    RestTemplate restTemplate(){
        return new RestTemplate();
    }
}


@EnableHystrix 注意熔断配置

 

控制器服务:


@RestController
public class HelloController {

    @Autowired
    HelloService helloService;


    @GetMapping(value = "hello")
    public String hello(@RequestParam String name){
        return helloService.hello(name);
    }
}

 

服务层定义:


@Service
public class HelloService {

    @Autowired
    RestTemplate restTemplate;

    @HystrixCommand(fallbackMethod = "error")
    public String hello(String name){
        return restTemplate.getForObject("http://CLOUD-SERVICE/hello?name="+name, String.class);
    }

    public String error(String name){
        return "sorry, error";
    }
}


注意熔断配置,熔断后调用error方法


HelloService 声明注入 RestTemplate,RestTemplate是 spring提供的用于访问Rest服务的客户端。
可通过 ClientHttpRequestFactory 指定不同的 Http 请求实现。
SimpleClientHttpRequestFactory 使用 J2SE提供的方式,HttpComponentsClientHttpRequestFactory 使用的是 HttpClient 实现。

 

启动测试:

1、启动两个 cloud-service实例,注意要设置不同的端口 8085和8086,

2、在启动服务消费者 cloud-consumer,可以在注册中心清晰的看到有两个服务提供者,一个服务消费者。

3、这时候访问消费者的接口 localhost:8083/hello?name=test 

4、不断刷新就会出现负载均衡的效果,
   页面返回 hello test i am from port 8085,hello test i am from port 8086,
   默认是轮询负载策略。

 

 

 

 

 

 

 

 

 

 

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值