zoukankan      html  css  js  c++  java
  • ribbon客户端负载均衡

    Ribbon简介

    参考:https://blog.csdn.net/chengqiuming/article/details/80711168

    Ribbon是Netflix发布的负载均衡器,它有助于控制HTTP和TCP的客户端的行为。为Ribbon配置服务提供者地址后,Ribbon就可基于某种负载均衡算法,自动地帮助服务消费者去请求。Ribbon默认为我们提供了很多负载均衡算法,例如轮询、随机等。当然,我们也可为Ribbon实现自定义的负载均衡算法。
    在Spring Cloud中,当Ribbon与Eureka配合使用时,Ribbon可自动从Eureka Server获取服务提供者地址列表,并基于负载均衡算法,请求其中一个服务提供者实例。展示了Ribbon与Eureka配合使用时的架构

    客户端负责均衡

    负载均衡又区分了两种类型:

    1. 客户端负载均衡(Ribbon)
      服务实例的清单在客户端,客户端进行负载均衡算法分配。
      (从上面的知识我们已经知道了:客户端可以从Eureka Server中得到一份服务清单,在发送请求时通过负载均衡算法,在多个服务器之间选择一个进行访问)
    2. 服务端负载均衡(Nginx)
      服务实例的清单在服务端,服务器进行负载均衡算法分配

    客户端负责均衡ribbon

    graph TD
    服务消费者-->ribbon
    ribbon-->服务清单1
    ribbon-->服务清单2
    ribbon-->服务清单3
    服务清单1-->eureka里的服务1
    服务清单2-->eureka里的服务2
    服务清单3-->eureka里的服务3
    

    使用

    @EnableDiscoveryClient
    @SpringBootApplication
    public class ConsumerMovieApplication {
      @Bean
      @LoadBalanced
      public RestTemplate restTemplate() {
        return new RestTemplate();
      }
     
      public static void main(String[] args) {
        SpringApplication.run(ConsumerMovieApplication.class, args);
      }
    
    }
    

    程序代码,使用负载均衡

    
    @RestController
    public class MovieController {
      private static final Logger LOGGER = LoggerFactory.getLogger(MovieController.class);
      @Autowired
      private RestTemplate restTemplate;
      @Autowired
      private LoadBalancerClient loadBalancerClient;
     
      @GetMapping("/user/{id}")
      public User findById(@PathVariable Long id) {
        //VIP:virtual IP
        return this.restTemplate.getForObject("http://microservice-provider-user/" + id, User.class);
      }
     
      @GetMapping("/log-user-instance")
      public void logUserInstance() {
        ServiceInstance serviceInstance = this.loadBalancerClient.choose("microservice-provider-user");
        // 打印当前选择的是哪个节点
        MovieController.LOGGER.info("{}:{}:{}", serviceInstance.getServiceId(), serviceInstance.getHost(), serviceInstance.getPort());
      }
    }
    
    

    配置

    server:
      port: 8010
    spring:
      application:
        name: microservice-consumer-movie
    eureka:
      client:
        serviceUrl:
          defaultZone:http://localhost:8761/eureka/
      instance:
        prefer-ip-address: true
    
    

    测试

    1. 启动eureka微服务
    2. 启动movie-ribbon微服务
    3. 启动一个user微服务
    4. 启动第二个user微服务
    5. 观察eureka的变化
  • 相关阅读:
    心得体悟帖---200209(效率太低的事情我是不会做的,这个可以解释我所有的行为)
    心得体悟帖---200209(顺心而动的睡觉方式(6+1或者5+2的睡觉方式))
    按钮用图片做背景hover时闪烁
    范仁义Emmet课程---1、HTML速写之Emmet语法规则
    CSS3疑难问题---5、:before和::before的区别
    reset.css是什么
    日常英语---200209(Abbreviations(Emmet Abbreviations Syntax))
    日常英语---200209(relative(layer model))
    日常英语---200209(Emmet Abbreviations Syntax)
    伪元素和伪类在chrome浏览器里面还是比较好区分的
  • 原文地址:https://www.cnblogs.com/lori/p/11112729.html
Copyright © 2011-2022 走看看