• Spring Cloud 学习 (二) Ribbon


    负载均衡是指将负载分摊到多个执行单元上,常见的负载均衡有两种方式:一种是独立进程单元,通过负载均衡策略,将请求转发到不同的执行单元上,例如 Ngnix;另一种是将负载均衡逻辑以代码的形式封装到服务消费者的客户端上,服务消费者客户端维护了一份服务提供者的信息列表,有了信息列表,通过负载均衡策略将请求分摊给多个服务提供者,从而达到负载均衡的目的,例如 Ribbon

    新建 spring-cloud-eureka-ribbon-client Module

    pom

    <parent>
        <artifactId>spring-cloud-parent</artifactId>
        <groupId>com.karonda</groupId>
        <version>1.0.0</version>
    </parent>
    <modelVersion>4.0.0</modelVersion>
    
    <artifactId>spring-cloud-eureka-ribbon-client</artifactId>
    
    <dependencies>
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-data-rest</artifactId>
        </dependency>
        <dependency>
            <groupId>org.springframework.cloud</groupId>
            <artifactId>spring-cloud-starter-netflix-eureka-client</artifactId>
        </dependency>
        <dependency>
            <groupId>org.springframework.cloud</groupId>
            <artifactId>spring-cloud-starter-netflix-ribbon</artifactId>
        </dependency>
    </dependencies>
    
    <build>
        <plugins>
            <plugin>
                <groupId>org.springframework.boot</groupId>
                <artifactId>spring-boot-maven-plugin</artifactId>
            </plugin>
        </plugins>
    </build>
    

    application.yml

    server:
      port: 8021
    
    eureka:
      client:
        service-url:
          defaultZone: http://localhost:8001/eureka/
    
    spring:
      application:
        name: ribbon-client
    

    启动类

    @EnableEurekaClient
    @SpringBootApplication
    public class EurekaRibbonClientApp {
        public static void main(String[] args){
            SpringApplication.run(EurekaRibbonClientApp.class, args);
        }
    }
    

    RestTemplate

    @Configuration
    public class RibbonConfig {
        @Bean
        @LoadBalanced // 开启负载均衡功能
        RestTemplate restTemplate(){
            return new RestTemplate();
        }
    }
    

    Service

    @Service
    public class RibbonService {
        @Autowired
        RestTemplate restTemplate;
    
        public String hi(String name){
            return restTemplate.getForObject("http://eureka-client/hi?name=" + name, String.class);
        }
    }
    

    Controller

    @RestController
    public class RibbonController {
        @Autowired
        RibbonService ribbonService;
    
        @GetMapping("/hi")
        public String hi(@RequestParam String name){
            return ribbonService.hi(name);
        }
    }
    

    测试

    1. 启动 eureka-server
    2. 启动 eureka-client (两个实例:一个 8011 端口,一个 8012 端口)
    3. 启动 eureka-ribbon-client

    多次访问 http://localhost:8021/hi?name=victor 可以看到 8011 和 8012 端口交替出现

    完整代码:GitHub

    本人 C# 转 Java 的 newbie, 如有错误或不足欢迎指正,谢谢

  • 相关阅读:
    [BZOJ 1698] 荷叶池塘
    [BZOJ 3132] 上帝造题的七分钟
    [JLOI2011] 飞行路线
    [Codeforces Round49F] Session in BSU
    [BZOJ 3036] 绿豆蛙的归宿
    CRC-16校验原理
    ubuntu下mysql的安装与配置
    【OpenCV】边缘检测:Sobel、拉普拉斯算子
    我对sobel算子的理解
    梯度算子(普通的+Robert + sobel + Laplace)
  • 原文地址:https://www.cnblogs.com/victorbu/p/11007755.html
Copyright © 2020-2023  润新知