Spring Cloud项目(四)——使用Ribbon作为负载均衡

前期准备

一个使用nacos作为注册中心的springcloud项目,

项目结构

在这里插入图片描述

步骤

1、新建模块springcloud-provider2,并复制原springcloud-provider模块的代码及依赖到该模块中
2、修改启动类名称、UserService里的对象内容及yml里的服务端口
3、按顺序启动:nacos、provider、provider2、consumer

测试结果

在这里插入图片描述
浏览器访问localhost:8081/consumer/findById/2
在这里插入图片描述
刷新该页面:
在这里插入图片描述

经过测试发现,我们不断的在这两个对象之间进行切换,这是因为负载均衡在帮我们选择该使用哪一个provider。

什么是负载均衡

负载均衡是高可用网络基础架构的关键组件,通常用于将工作负载分布到多个服务器来提高网站、应用、数据库或其他服务的性能和可靠性。

一个没有负载均衡的 web 架构类似下面这样:
在这里插入图片描述

在这里用户是直连到 web服务器,如果这个服务器宕机了,那么用户自然也就没办法访问了。另外,如果同时有很多用户试图访问服务器,超过了其能处理的极限,就会出现加载速度缓慢或根本无法连接的情况。

而通过在后端引入一个负载均衡器和至少一个额外的 web 服务器,可以缓解这个故障。通常情况下,所有的后端服务器会保证提供相同的内容,以便用户无论哪个服务器响应,都能收到一致的内容。

在这里插入图片描述
常见的负载均衡方式有两种:

  • 服务端负载均衡
  • 客户端负载均衡

服务端负载均衡
在这里插入图片描述
服务端负载均衡具有以下特点:

  • 需要建立一个独立的负载均衡服务器。
  • 负载均衡是在客户端发送请求后进行的,因此客户端并不知道到底是哪个服务端提供的服务。
  • 可用服务端清单存储在负载均衡服务器上。

客户端负载均衡
在这里插入图片描述
客户端负载均衡具有以下特点:

  • 负载均衡器位于客户端,不需要单独搭建一个负载均衡服务器
  • 负载均衡是在客户端发送请求前进行的,因此客户端清楚地知道是哪个服务端提供的服务。
  • 客户端都维护了一份可用服务清单,而这份清单都是从服务注册中心获取的。

既然如此,我之前又在哪里使用了负载均衡吗?
在这里插入图片描述
其实,LoadBalancerClient就是使用的Ribbon作为负载均衡

什么是Ribbon

Spring Cloud Ribbon是一个基于HTTP和TCP的客户端负载均衡工具,它基于Netflix Ribbon实现。通过Spring Cloud的封装,可以让我们轻松地将面向服务的REST模版请求自动转换成客户端负载均衡的服务调用。Spring Cloud Ribbon虽然只是一个工具类框架,它不像服务注册中心、配置中心、API网关那样需要独立部署,但是它几乎存在于每一个Spring Cloud构建的微服务和基础设施中。因为微服务间的调用,API网关的请求转发等内容,实际上都是通过Ribbon来实现的

Ribbon的负载均衡策略

不断跟踪代码,发现IRule接口就是用来实现负载均衡策略的
在这里插入图片描述

  • RandomRule:随机策略,就是从服务器中随机选择一个服务器,
  • RoundRobinRule:轮询策略,表示每次都取下一个服务器。比如一共有5台服务器,第1次取第1台,第2次取第2台,第3次取第3台,以此类推。也是ribbon的默认策略
  • WeightedResponseTimeRule:继承了RoundRobinRule,开始的时候还没有权重列表,采用父类的轮询方式,有一个默认每30秒更新一次权重列表的定时任务,该定时任务会根据实例的响应时间来更新权重列表,choose方法做的事情就是,用一个(0,1)的随机double数乘以最大的权重得到randomWeight,然后遍历权重列表,找出第一个比randomWeight大的实例下标,然后返回该实例
  • BestAvailableRule策略用来选取最少并发量请求的服务器

自定义使用其他策略

修改之前consumer的config类

package com.lx.config;

import com.netflix.loadbalancer.IRule;
import com.netflix.loadbalancer.RandomRule;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;
import org.springframework.web.client.RestTemplate;

@Configuration
public class RestTemplateConfig {

    @Bean
    public RestTemplate getRestTemplate(){
        return new RestTemplate();
    }
    
    /**
     * 设置负载均衡的策略
     */ 
    @Bean
    public IRule rule(){
        return new RandomRule();
    }
}

扩展

服务端负载均衡与客户端负载均衡对比:
在这里插入图片描述

附:参考资料

1、什么是负载均衡?
2、Ribbon:Spring Cloud负载均衡与服务调用组件(非常详细)
3、Ribbon详解
4、Ribbon的负载均衡策略及原理

结语

下面关于Spring Cloud学习系列的博客的连接有的是不能使用的,因为博主还在努力创作中,敬请期待

附:Spring Cloud学习系列

Spring Cloud项目(一)——集成Nacos作为注册中心
Spring Cloud项目(二)——集成Nacos作为配置中心
Spring Cloud项目(三)——实现Nacos数据信息持久化到MySQL
Spring Cloud项目(四)——使用Ribbon作为负载均衡
Spring Cloud项目(五)——使用openFeign作为服务调用
Spring Cloud项目(六)——使用sentinel作为流量管理
Spring Cloud项目(七)——使用sentinel作为限流和熔断
Spring Cloud项目(八)——使用gateway作为服务网关

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

--流星。

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值