滚雪球学SpringCloud[2.3]:服务发现与负载均衡详解

全文目录:

    • 前言
    • 1. Ribbon的使用与配置
      • 1.1 Ribbon 概述
        • Ribbon 的核心功能:
      • 1.2 Ribbon 的基本使用
        • 1.2.1 引入 Ribbon 依赖
        • 1.2.2 配置 `RestTemplate` 与 Ribbon
        • 1.2.3 示例:通过 Ribbon 调用服务
      • 1.3 Ribbon 的配置选项
    • 2. Ribbon的负载均衡策略
      • 2.1 内置的负载均衡策略
      • 2.2 自定义负载均衡策略
      • 2.3 负载均衡策略的选择
    • 3. 与Eureka的集成
      • 3.1 Ribbon 与 Eureka 的集成原理
      • 3.2 Eureka 与 Ribbon 的无缝集成
    • 小结
    • 下期预告

前言

在上一节【2.2 Consul与Zookeeper服务注册】中,我们探讨了 Consul 和 Zookeeper 作为服务注册中心的工作原理、应用场景以及它们与 Eureka 的对比。服务注册中心的主要职责是帮助服务动态地注册和发现,确保微服务之间能够灵活通信。虽然服务注册为微服务的动态扩展提供了支持,但要真正实现系统的高可用性和性能优化,负载均衡同样至关重要。

在微服务架构中,负载均衡可以分为两类:服务端负载均衡(如 Nginx)和客户端负载均衡(如 Ribbon)。服务端负载均衡集中控制流量分发,而客户端负载均衡则将决策放在服务调用方,由客户端选择最优服务实例进行请求分发。在 Spring Cloud 微服务生态系统中,Ribbon 是最常用的客户端负载均衡工具。本节将重点介绍 Ribbon 的使用与配置Ribbon 的负载均衡策略,以及它如何与 Eureka 集成实现高效的服务发现与流量调度。

1. Ribbon的使用与配置

1.1 Ribbon 概述

Ribbon 是 Netflix 开源的客户端负载均衡器。它允许客户端在多个服务实例之间进行流量分发,并根据配置的策略选择最佳服务实例。与传统的服务端负载均衡不同,Ribbon 的负载均衡逻辑发生在客户端,即调用方可以根据获取的服务实例列表,结合负载均衡策略来选择具体的服务实例进行调用。

Ribbon 的核心功能:
  • 客户端负载均衡:客户端自动选择服务实例,减少对外部负载均衡设备的依赖。
  • 重试机制:如果选定的服务实例不可用,Ribbon 会自动重试其他可用的实例。
  • 动态服务发现:Ribbon 可以与 Eureka 集成,动态获取服务实例列表,适应服务的扩展和缩减。
  • 多种负载均衡策略:提供内置的多种负载均衡算法,如随机、轮询、加权等。

1.2 Ribbon 的基本使用

在 Spring Cloud 中,Ribbon 已默认与 RestTemplate 集成,通过添加简单的配置即可启用负载均衡。以下是如何使用 Ribbon 进行负载均衡的步骤:

1.2.1 引入 Ribbon 依赖

首先,在 pom.xml 文件中引入 Ribbon 相关的依赖。如果你已经使用了 Spring Cloud 的 Eureka 或其他服务发现工具,Ribbon 通常会自动包含,但仍可以显式添加:

<dependency><groupId>org.springframework.cloud</groupId><artifactId>spring-cloud-starter-netflix-ribbon</artifactId>
</dependency>
1.2.2 配置 RestTemplate 与 Ribbon

通过 RestTemplate 实现负载均衡非常简单,只需在创建 RestTemplate 实例时,添加 @LoadBalanced 注解即可:

import org.springframework.cloud.client.loadbalancer.LoadBalanced;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;
import org.springframework.web.client.RestTemplate;@Configuration
public class RibbonConfig {@Bean@LoadBalancedpublic RestTemplate restTemplate() {return new RestTemplate();}
}

这个配置会告诉 Spring Cloud,RestTemplate 需要使用 Ribbon 进行负载均衡。这样,当我们通过 RestTemplate 调用服务时,Ribbon 会从服务注册中心(如 Eureka)获取服务实例列表,并根据配置的负载均衡策略选择最优的服务实例。

1.2.3 示例:通过 Ribbon 调用服务

假设有一个名为 user-service 的微服务,已在 Eureka 注册。我们可以通过服务名直接调用,而不需要关心具体的 IP 地址和端口号:

import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.RestController;
import org.springframework.web.client.RestTemplate;@RestController
public class UserController {private final RestTemplate restTemplate;public UserController(RestTemplate restTemplate) {this.restTemplate = restTemplate;}@GetMapping("/get-user")public String getUser() {return restTemplate.getForObject("http://user-service/user", String.class);}
}

在这个例子中,user-service 是在 Eureka 中注册的服务名,Ribbon 会自动从 Eureka 获取该服务的可用实例,并根据负载均衡策略选择一个实例进行调用。

1.3 Ribbon 的配置选项

Ribbon 提供了多种配置选项,允许开发者自定义服务调用行为,如超时设置、重试次数、负载均衡策略等。这些配置可以通过 application.ymlapplication.properties 文件进行调整。

user-service:ribbon:ConnectTimeout: 3000      # 连接超时时间(毫秒)ReadTimeout: 5000         # 读取超时时间(毫秒)MaxAutoRetries: 3         # 最大重试次数MaxAutoRetriesNextServer: 2 # 切换到其他服务实例的重试次数OkToRetryOnAllOperations: true # 是否允许在所有操作中进行重试

这些配置可以优化服务调用的可靠性,特别是在高并发或服务实例状态动态变化的情况下,设置合理的超时和重试策略可以提升系统的稳定性。

2. Ribbon的负载均衡策略

2.1 内置的负载均衡策略

Ribbon 提供了多种内置的负载均衡策略,开发者可以根据实际业务需求选择合适的策略。这些策略通过 IRule 接口实现,开发者可以在配置中灵活地指定不同的负载均衡算法。

以下是 Ribbon 中几种常见的负载均衡策略:

  1. 轮询策略(RoundRobinRule)

    • Ribbon 按照服务实例的顺序,轮流选择可用的实例进行调用。此策略非常适合负载均衡需求明确、服务实例性能相对均衡的场景。
    @Bean
    public IRule ribbonRule() {return new RoundRobinRule(); // 使用轮询策略
    }
    
  2. 随机策略(RandomRule)

    • 随机选择服务实例进行调用,适合服务实例性能差异较大或需要平均分配流量的场景。
    @Bean
    public IRule ribbonRule() {return new RandomRule(); // 使用随机策略
    }
    
  3. 加权响应时间策略(WeightedResponseTimeRule)

    • 根据每个服务实例的响应时间来动态调整权重,响应时间越短的实例分配的请求越多。适合服务性能不均衡、需要根据实际性能进行流量分配的场景。
    @Bean
    public IRule ribbonRule() {return new WeightedResponseTimeRule(); // 使用基于响应时间的权重策略
    }
    
  4. 最小并发策略(BestAvailableRule)

    • Ribbon 会优先选择当前并发请求数最少的服务实例,适用于需要减少高并发场景下单个实例负载的情况。
    @Bean
    public IRule ribbonRule() {return new BestAvailableRule(); // 选择并发最小的服务实例
    }
    
  5. 区域感知策略(ZoneAvoidanceRule)

    • 根据服务实例的所在区域和性能指标来选择实例,适合跨数据中心或跨区域部署的场景。
    @Bean
    public IRule ribbonRule() {return new ZoneAvoidanceRule(); // 区域感知策略
    }
    

2.2 自定义负载均衡策略

虽然 Ribbon 提供了多种内置策略,但在某些特殊场景下,我们可能需要自定义负载均衡策略。例如,当我们希望根据服务实例的某些自定义指标(如 CPU 负载、响应时间、地理位置等)进行流量分发时,可以通过实现 Ribbon 的 IRule 接口来自定义策略:

import com.netflix.loadbalancer.Server;
import com.netflix.loadbalancer.AbstractLoadBalancerRule;
import java.util.List;public class CustomLoadBalancerRule extends AbstractLoadBalancerRule {@Overridepublic Server choose(Object key) {List<Server> servers = getLoadBalancer().getReachableServers();// 根据自定义逻辑选择服务实例return servers.get(0); // 返回选定的实例}@Overridepublic void initWithNiwsConfig(IClientConfig clientConfig) {// 初始化自定义配置}
}

通过这样的自定义策略,开发者可以将业务需求与负载均衡深度结合,确保服务的调用逻辑更加灵活和精确。

2.3 负载均衡策略的选择

选择合适的负载均衡策略至关重要。不同的策略适合不同的场景,例如:

  • 如果服务实例性能均衡,轮询策略可以较好地分配负载。
  • 如果服务实例响应时间差异较大,加权响应时间策略能够优化流量分发。
  • 对于需要动态适应负载和响应的场景,区域感知策略或自定义策略能够提供更灵活的负载分发能力。

负载均衡策略的选择应根据系统的业务特性、服务的性能状况和调用的频率等因素进行调整,从而在高并发场景下保证系统的性能和稳定性。

3. 与Eureka的集成

3.1 Ribbon 与 Eureka 的集成原理

Ribbon 和 Eureka 的集成是 Spring Cloud 中常见的架构模式。Eureka 作为服务注册中心,负责管理所有服务实例的状态信息,而 Ribbon 作为客户端负载均衡器,从 Eureka 中获取服务实例列表,结合负载均衡策略选择合适的实例进行调用。

当服务在 Eureka 注册中心注册后,Ribbon 会定期从 Eureka 获取服务实例的状态信息。Ribbon 将这些实例缓存到本地,并根据配置的负载均衡策略(如轮询、随机等)选择一个健康的实例进行请求调用。这种集成方式使得服务能够动态扩展、缩减,提供了极大的灵活性和高可用性。

3.2 Eureka 与 Ribbon 的无缝集成

在 Spring Cloud 中,Ribbon 和 Eureka 的集成非常简单。只要 Eureka 和 Ribbon 都配置到项目中,Spring Cloud 会自动将它们集成在一起,开发者只需通过 RestTemplate 或 Feign 调用服务时,Ribbon 就会使用 Eureka 的服务发现功能获取实例列表。

以下是 Eureka 与 Ribbon 集成的步骤:

  1. application.yml 中配置 Eureka 服务地址

    eureka:client:service-url:defaultZone: http://localhost:8761/eureka/
    
  2. 注册服务到 Eureka:当微服务启动时,服务会自动注册到 Eureka,Ribbon 会从 Eureka 拉取服务列表。

  3. 通过 Ribbon 进行负载均衡调用:在服务调用时,Ribbon 会根据 Eureka 提供的服务列表和配置的负载均衡策略进行流量分发:

    restTemplate.getForObject("http://user-service/user", String.class);
    

Ribbon 和 Eureka 的结合确保了系统的动态可扩展性和高可用性。Ribbon 可以处理服务实例的动态变化,而 Eureka 提供服务注册和发现,二者共同构建了一个健壮的服务调用与负载均衡体系。

小结

本节详细介绍了 Ribbon 的使用和配置,以及它如何与 Eureka 集成实现动态负载均衡。通过 Ribbon,客户端可以根据多种负载均衡策略选择服务实例,确保流量在不同实例之间合理分配。与 Eureka 集成后,Ribbon 可以动态获取服务实例列表,实现更加灵活的微服务架构。

负载均衡是确保高并发场景下系统性能和稳定性的关键,Ribbon 提供了丰富的策略和扩展能力,开发者可以根据业务需求选择或自定义合适的负载均衡策略。

下期预告

在下一节【3.1 Feign:声明式服务调用】中,我们将探讨如何通过 Feign 实现更加简洁的声明式服务调用,进一步简化微服务之间的通信。敬请期待!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/879429.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Python_两个jpg图片文件名称互换

项目场景 处理Adobe Photoshop导出的两个切片的顺序错误问题 小编在进行图片切片处理的时候&#xff0c;发现用PS导出的切片顺序错误&#xff0c;例如用PS导出的切片分别为test_01.jpg&#xff0c;test_02.jpg&#xff0c;但实际的使用需求是将两个图片的顺序调换&#xff0c…

self-play RL学习笔记

让AI用随机的路径尝试新的任务&#xff0c;如果效果超预期&#xff0c;那就更新神经网络的权重&#xff0c;使得AI记住多使用这个成功的事件&#xff0c;再开始下一次的尝试。——llya Sutskever 这两天炸裂朋友圈的OpenAI草莓大模型o1和此前代码能力大幅升级的Claude 3.5&…

基于less和scss 循环生成css

效果 一、less代码 复制代码 item-count: 12; // 生成多少个 .item 类.item-loop(n) when (n > 0) {.icon{n} {background: url(../../assets/images/menu/icon{n}.png) no-repeat;background-size: 100% 100%;}.item-loop(n - 1);}.item-loop(item-count);二、scss代码 f…

【人工智能】Transformers之Pipeline(十七):文本分类(text-classification)

目录 一、引言 二、文本分类&#xff08;text-classification&#xff09; 2.1 概述 2.2 DistilBERT—BERT 的精简版&#xff1a;更小、更快、更便宜、更轻便 2.3 应用场景​​​​​​​ 2.4 pipeline参数 2.4.1 pipeline对象实例化参数 2.4.2 pipeline对象使用参数 …

【Hot100】LeetCode—287. 寻找重复数

目录 1- 思路题目识别快慢指针-类比链表判环 2- 实现⭐31. 下一个排列——题解思路 3- ACM 实现 原题链接&#xff1a;287. 寻找重复数 1- 思路 题目识别 识别1 &#xff1a;给定一个数组&#xff0c;寻找数组中的重复数。必须用 O(1) 的空间复杂度&#xff0c;且不能修改数组…

VMware Fusion Pro 13 Mac版虚拟机 安装Win11系统教程

Mac分享吧 文章目录 Win11安装完成&#xff0c;软件打开效果一、VMware安装Windows11虚拟机1️⃣&#xff1a;准备镜像2️⃣&#xff1a;创建虚拟机3️⃣&#xff1a;虚拟机设置4️⃣&#xff1a;安装虚拟机5️⃣&#xff1a;解决连不上网问题 安装完成&#xff01;&#xff0…

fuxa搭建与使用(web组态)

1. 安装Node.js -> npm安装 参考网址&#xff1a;https://blog.csdn.net/WHF__/article/details/129362462 一、安装运行 C:\WINDOWS\system32>node -v v20.17.0 C:\WINDOWS\system32>npm -v 10.8.2 二、环境配置 在安装路径&#xff08;D:\Program_Files\nodejs&a…

[数据集][目标检测]车油口挡板开关闭合检测数据集VOC+YOLO格式138张2类别

数据集格式&#xff1a;Pascal VOC格式YOLO格式(不包含分割路径的txt文件&#xff0c;仅仅包含jpg图片以及对应的VOC格式xml文件和yolo格式txt文件) 图片数量(jpg文件个数)&#xff1a;138 标注数量(xml文件个数)&#xff1a;138 标注数量(txt文件个数)&#xff1a;138 标注类别…

【2024.08】图模互补:知识图谱与大模型融合综述-笔记

阅读目的&#xff1a;假设已有一个知识图谱&#xff0c;如何利用图谱增强模型的问答&#xff0c;如何检索知识图谱、知识图谱与模型的文本如何相互交互、如何利用知识图谱增强模型回答的可解释性。 从综述中抽取感兴趣的论文进一步阅读。 来源&#xff1a;图模互补&#xff1…

Docker零基础入门

参考课程https://www.bilibili.com/video/BV1VC4y177re/?vd_source=b15169a302bee35f484245aecc69d4dd 参考书籍Docker 实践 - 面向 AI 开发人员的 Docker 实践 (dockerpractice.readthedocs.io) 1. 什么是Docker 1.1. Docker起源 随着计算机的发展,计算机上已经可以运行多…

CAN通讯常见错误纠正

CAN通讯常见错误 1.在使用CAN设备进行数据通讯时&#xff0c;有时候参数配置不当可能就会导致通讯的失败&#xff0c;如下图1所示&#xff0c;出现通信错误的原因是两个设备的波特率配置不一致导致。 图1 2.有时候在配置参数的时候&#xff0c;不能只关注波特率速度配置一致就…

Script-server: 一款开源的脚本管理工具,为你的Python脚本提供一个直观的 Web UI

在日常工作中&#xff0c;我们经常会使用各种脚本来自动化任务&#xff0c;提升效率。但传统的脚本管理方式往往伴随着一些困扰&#xff1a;复杂的命令行操作、难以理解的脚本参数、缺乏直观的反馈等等。这些问题&#xff0c;让原本应该便捷的脚本管理变得繁琐。 Script-server…

太速科技-基于XC7Z100+AD9361的双收双发无线电射频板卡

基于XC7Z100AD9361的双收双发无线电射频板卡 一、板卡概述 基于XC7Z100AD9361的双收双发无线电射频板卡是基于Xilinx ZYNQ FPGA和ADI的无线收发芯片AD9361开发的专用功能板卡&#xff0c;用于4G小基站&#xff0c;无线图传&#xff0c;数据收发等领域。 二、板卡…

QQ频道机器人零基础开发详解(基于QQ官方机器人文档)[第三期]

QQ频道机器人零基础开发详解(基于QQ官方机器人文档)[第三期] 第三期介绍&#xff1a;频道模块之频道成员 目录 QQ频道机器人零基础开发详解(基于QQ官方机器人文档)[第三期]第三期介绍&#xff1a;频道模块之频道成员获取子频道在线成员数获取频道成员列表获取频道身份组成员列…

Java项目: 基于SpringBoot+mybatis+maven课程答疑系统(含源码+数据库+毕业论文)

一、项目简介 本项目是一套基于SpringBootmybatismaven课程答疑系统 包含&#xff1a;项目源码、数据库脚本等&#xff0c;该项目附带全部源码可作为毕设使用。 项目都经过严格调试&#xff0c;eclipse或者idea 确保可以运行&#xff01; 该系统功能完善、界面美观、操作简单、…

102.WEB渗透测试-信息收集-FOFA语法(2)

免责声明&#xff1a;内容仅供学习参考&#xff0c;请合法利用知识&#xff0c;禁止进行违法犯罪活动&#xff01; 内容参考于&#xff1a; 易锦网校会员专享课 上一个内容&#xff1a;101.WEB渗透测试-信息收集-FOFA语法&#xff08;1&#xff09; FOFA使用实例 • title&q…

资深盘点:国内外知名的ERP管理系统厂商有哪些?

已经考虑引入ERP系统却担心面临以下问题&#xff1f;ERP系统流程僵化难以调整&#xff1f;流程与实际业务脱节&#xff1f;培训不到位、技术支持不及时导致难以实现全员使用、共创&#xff1f;市面上的ERP系统众多不知道如何选择&#xff1f; 今天就根据2024最新市场动态&…

ISAC: Toward Dual-Functional Wireless Networks for 6G and Beyond【论文阅读笔记】

此系列是本人阅读论文过程中的简单笔记&#xff0c;比较随意且具有严重的偏向性&#xff08;偏向自己研究方向和感兴趣的&#xff09;&#xff0c;随缘分享&#xff0c;共同进步~ Integrated Sensing and Communications: Toward Dual-Functional Wireless Networks for 6G and…

react crash course 2024 (1)理论概念

state的作用 react hooks 而无需写一个class jsx 样式用 spa

决策树算法上篇

决策树概述 决策树是属于有监督机器学习的一种&#xff0c;起源非常早&#xff0c;符合直觉并且非常直观&#xff0c;模仿人类做决策的过程&#xff0c;早期人工智能模型中有很多应用&#xff0c;现在更多的是使用基于决策树的一些集成学习的算法。 示例一&#xff1a; 上表根据…