SpringCloud-Ribbon负载均衡

Spring Cloud Ribbon

目录

简介

RestTemplate的使用

依赖

测试使用演示

ribbon常用配置

负载均衡策略

简介

Spring Cloud Netflix子项目的核心组件之一,主要给服务间调用及API网关
转发提供负载均衡的功能。其中负载均衡均衡可以增加系统的可用性和扩展性。不多
做赘述。

RestTemplate的使用

RestTemplate是一个HTTP客户端,我们可以使用它调用HTTP接口,支持GET、POST
、PUT、DELETE等restful风格的接口方法。

依赖

说明,springcloud依赖中已经默认包含了部分ribbon的依赖,不引入此依赖也能正常使用负载均衡功能,使用的时候应该注意一下。

<!--ribbon负载均衡依赖-->
        <dependency>
            <groupId>org.springframework.cloud</groupId>
            <artifactId>spring-cloud-starter-netflix-ribbon</artifactId>
        </dependency>

测试使用演示

创建一个eureka-target-service微服务工程

在这里插入图片描述

在eureka-target-service的pom下添加依赖

<dependencyManagement>
        <dependencies>
            <dependency>
                <groupId>org.springframework.cloud</groupId>
                <artifactId>spring-cloud-dependencies</artifactId>
                <version>${spring-cloud.version}</version>
                <type>pom</type>
                <scope>import</scope>
            </dependency>
        </dependencies>
    </dependencyManagement>

    <dependencies>
        <!--包含springboot启动依赖,springcloud是基于springboot理所当然也包含springboot的依赖,详情自己ctrl+左击点进去-->
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-web</artifactId>
        </dependency>
        <dependency>
            <groupId>org.springframework.cloud</groupId>
            <artifactId>spring-cloud-starter-netflix-eureka-client</artifactId>
        </dependency>
        <!--本项目的工具包-->
        <dependency>
            <groupId>com.zxf</groupId>
            <artifactId>common</artifactId>
            <version>1.0-SNAPSHOT</version>
        </dependency>
    </dependencies>

创建两个配置文件(启动服务时加载不同的配置文件)

在这里插入图片描述
在这里插入图片描述

创建对外接口

在这里插入图片描述

启动eureka注册中心,同时启动两个加载不同配置文件的此服务

在这里插入图片描述

创建一个以负载均衡方式调用此服务的微服务工程

在这里插入图片描述

在pom中添加相对应的依赖

<properties>
        <java.version>1.8</java.version>
        <spring-cloud.version>Hoxton.SR6</spring-cloud.version>
    </properties>

    <dependencyManagement>
        <dependencies>
            <dependency>
                <groupId>org.springframework.cloud</groupId>
                <artifactId>spring-cloud-dependencies</artifactId>
                <version>${spring-cloud.version}</version>
                <type>pom</type>
                <scope>import</scope>
            </dependency>
        </dependencies>
    </dependencyManagement>

    <dependencies>
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-web</artifactId>
        </dependency>
        <!--ribbon负载均衡依赖-->
        <dependency>
            <groupId>org.springframework.cloud</groupId>
            <artifactId>spring-cloud-starter-netflix-ribbon</artifactId>
        </dependency>
        <dependency>
            <groupId>org.springframework.cloud</groupId>
            <artifactId>spring-cloud-starter-netflix-eureka-client</artifactId>
        </dependency>
        <dependency>
            <groupId>com.zxf</groupId>
            <artifactId>common</artifactId>
            <version>1.0-SNAPSHOT</version>
        </dependency>
    </dependencies>

添加配置信息

server.port=9001
spring.application.name=ribbon

eureka.client.service-url.defaultZone=http://root:root@localhost:10000/eureka/
eureka.client.register-with-eureka=true
eureka.client.fetch-registry=true

添加RestTemplate类

@Configuration
//@Configurable//通常用于对象new的时候,在构造函数之前让spring注入对象
public class BeanConfig {

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

}

创建调用服务的类

在这里插入图片描述

查看eureka注册的服务

在这里插入图片描述

测试

在这里插入图片描述
在这里插入图片描述

ribbon常用配置

全局配置

ribbon:
  ConnectTimeout: 1000 #服务请求连接超时时间(毫秒)
  ReadTimeout: 3000 #服务请求处理超时时间(毫秒)
  OkToRetryOnAllOperations: true #对超时请求启用重试机制
  MaxAutoRetriesNextServer: 1 #切换重试实例的最大个数
  MaxAutoRetries: 1 # 切换实例后重试最大次数
  NFLoadBalancerRuleClassName: com.netflix.loadbalancer.RandomRule #修改负载均衡算法

指定服务配置

target:
	ribbon:
	  ConnectTimeout: 1000 #服务请求连接超时时间(毫秒)
	  ReadTimeout: 3000 #服务请求处理超时时间(毫秒)
	  OkToRetryOnAllOperations: true #对超时请求启用重试机制
	  MaxAutoRetriesNextServer: 1 #切换重试实例的最大个数
	  MaxAutoRetries: 1 # 切换实例后重试最大次数
	  NFLoadBalancerRuleClassName: com.netflix.loadbalancer.RandomRule #修改负载均衡算法

负载均衡策略

RandomRule:随机
RoundRobinRule:轮询
RetryRule:在RoundRobinRule此基础上添加重试机制
WeightedResponseTimeRule:根据响应速度决定,速度越快,越容易被选择
BestAvailableRule:选择并发小的实例
AvailabilityFilteringRule:过滤故障实例,选择并发小的实例
ZoneAwareLoadBalancer:同时过滤不是统一区域的实例和故障实例,选择并发小的实例

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值