Spring Cloud LoadBalancer基础知识
LoadBalancer
- 概念
- 常见的负载均衡策略
- 使用随机选择的负载均衡策略
- 创建随机选择负载均衡器
- 配置
- Nacos 权重负载均衡器
- 创建 Nacos 负载均衡器
- 配置
- 自定义负载均衡器(根据IP哈希策略选择)
- 创建自定义负载均衡器
- 封装自定义负载均衡器
- 配置
- 缓存
概念
LoadBalancer(负载均衡器)是一种网络设备或软件机制, 用于分发传入的网络流量负载(请求)到多个后端目标服务器上, 从而实现系统资源的均衡利用和提高系统的可用性和性能
负载均衡分为服务器端负载均衡和客户端负载均衡
- 服务器端负载均衡是指放在服务器端的负载均衡器(反向代理), 如: Nginx, HAProxy, F5等
- 客户端负载均衡器是指嵌套在客户端的负载均衡器(正向代理), 如: Ribbon, Spring Cloud LoadBalancer等
服务器端负载均衡器所有请求都会发送到服务器端, 就会造成服务器端压力大的情况
常见的负载均衡策略
- 轮询(默认): 按照顺序将请求发送到服务器
- 随机选择: 随机选择一个服务器处理请求
- 最少连接: 选择连接数最少的一个服务器
- IP 哈希: 使用客户端IP地址计算哈希值然后发送到与之对应的服务器
- 加权轮询: 按照权重值的比例发送请求
- 加权随机选择: 按照权重值随机选择后端服务器
- 最短响应时间: 将请求发送到响应时间最短的服务器
Spring Cloud LoadBalancer 默认只支持轮询和随机选择, 但是可以自定义负载均衡策略
使用随机选择的负载均衡策略
创建随机选择负载均衡器
public class MyRandomLoadBalancer {@Beanpublic ReactorLoadBalancer<ServiceInstance> randomLoadBalancer(Environment environment,LoadBalancerClientFactory loadBalancerClientFactory) {String name = environment.getProperty(LoadBalancerClientFactory.PROPERTY_NAME);return new RandomLoadBalancer(loadBalancerClientFactory.getLazyProvider(name, ServiceInstanceListSupplier.class), name);}
}
配置

注意: 配置局部负载均衡器有可能不起作用, 可以配置全局负载均衡器

Nacos 权重负载均衡器
Nacos 中支持两种负载均衡器, 一种是权重负载均衡器, 另一种是第三方的CMDB(地域就近访问)标签负载均衡器, 我们可以将Spring Cloud LoadBalancer 直接配置为 Nacos 的负载均衡器
创建 Nacos 负载均衡器
@LoadBalancerClients(defaultConfiguration = MyNacosLoadBalancer.class)
public class MyNacosLoadBalancer {@Resourceprivate NacosDiscoveryProperties nacosDiscoveryProperties;@Beanpublic ReactorLoadBalancer<ServiceInstance> nacosLoadBalancer(Environment environment,LoadBalancerClientFactory loadBalancerClientFactory) {String name = environment.getProperty(LoadBalancerClientFactory.PROPERTY_NAME);return new NacosLoadBalancer(loadBalancerClientFactory.getLazyProvider(name, ServiceInstanceListSupplier.class),name, nacosDiscoveryProperties);}
}
配置

自定义负载均衡器(根据IP哈希策略选择)
创建自定义负载均衡器
public class CustomLoadBalancer implements ReactorServiceInstanceLoadBalancer {private static final Log log = LogFactory.getLog(RandomLoadBalancer.class);private final String serviceId;private ObjectProvider<ServiceInstanceListSupplier> serviceInstanceListSupplierProvider;public CustomLoadBalancer(ObjectProvider<ServiceInstanceListSupplier> serviceInstanceListSupplierProvider, String serviceId) {this.serviceId = serviceId;this.serviceInstanceListSupplierProvider = serviceInstanceListSupplierProvider;}public Mono<Response<ServiceInstance>> choose(Request request) {ServiceInstanceListSupplier supplier = (ServiceInstanceListSupplier)this.serviceInstanceListSupplierProvider.getIfAvailable(NoopServiceInstanceListSupplier::new);return supplier.get(request).next().map((serviceInstances) -> {return this.processInstanceResponse(supplier, serviceInstances);});}private Response<ServiceInstance> processInstanceResponse(ServiceInstanceListSupplier supplier, List<ServiceInstance> serviceInstances) {Response<ServiceInstance> serviceInstanceResponse = this.getInstanceResponse(serviceInstances);if (supplier instanceof SelectedInstanceCallback && serviceInstanceResponse.hasServer()) {((SelectedInstanceCallback)supplier).selectedServiceInstance((ServiceInstance)serviceInstanceResponse.getServer());}return serviceInstanceResponse;}private Response<ServiceInstance> getInstanceResponse(List<ServiceInstance> instances) {if (instances.isEmpty()) {if (log.isWarnEnabled()) {log.warn("No servers available for service: " + this.serviceId);}return new EmptyResponse();} else {ServletRequestAttributes attributes = (ServletRequestAttributes) RequestContextHolder.getRequestAttributes();HttpServletRequest request = attributes.getRequest();String ipAddress = request.getRemoteAddr();System.out.println("ip地址:" + ipAddress);int hash = instances.hashCode();int index = hash % instances.size();ServiceInstance instance = (ServiceInstance) instances.get(index);return new DefaultResponse(instance);}}
}
由于自定义负载均衡器和内置的负载均衡器只是在服务器选择的时候有所不同, 所以我们可以直接复制 RandomLoadBalancer 然后 在 getInstanceResponse()方法中进行改动即可
封装自定义负载均衡器

配置

缓存
Spring Cloud LoadBalancer 在获取实例时有两种选择:
- 及时获取: 每次都从注册中心获取到最新的实例, 效果好但是开销大
- 缓存服务列表: 每次得到服务列表后, 缓存一段时间,
spring Cloud LoadBalancer 默认缓存过期时间为 35s, 保存个数为 256个
我们也可以通过配置来改变这两个值
spring:cloud:loadbalancer:cache:ttl: 10capacity: 1000
# enabled: false 关闭缓存
生产环境下不要关闭缓存否则会降低性能
相关文章:
Spring Cloud LoadBalancer基础知识
LoadBalancer 概念常见的负载均衡策略使用随机选择的负载均衡策略创建随机选择负载均衡器配置 Nacos 权重负载均衡器创建 Nacos 负载均衡器配置 自定义负载均衡器(根据IP哈希策略选择)创建自定义负载均衡器封装自定义负载均衡器配置 缓存 概念 LoadBalancer(负载均衡器)是一种…...
剖析WPF模板机制的内部实现
剖析WPF模板机制的内部实现 众所周知,在WPF框架中,Visual类是可以提供渲染(render)支持的最顶层的类,所有可视化元素(包括UIElement、FrameworkElment、Control等)都直接或间接继承自Visual类。…...
计算机网络常见的名词解释
计算机网络常见的名词解释 1.应用层2.传输层3. 网络层4.链路层5. 无线网络和移动网络6.计算机网络中的安全 1.应用层 API (Application Programming Interface)应用程序编程接口HTTP (Hyper Text Transfer Protocol) 超文本传输协…...
Android Studio导入,删除第三方库
Android项目经常用到无私的程序员们提供的第三方类库。本篇博客就是实现第三方库的导入和删除。 一、导入第三方库 1、将需要的库下载到本地; 2、新建Moudle (1)File --- New Moudle (2)选择Android Library --- Next (3)填写Moudle名 --- Finish。一个新的Mou…...
生成指定长度的随机数字,用对方法精准提效数10倍!
生成指定长度的随机数字这一函数功能可能在以下情况下被使用: 密码生成:在需要生成随机密码时,可以使用该功能生成指定长度的随机数字作为密码。 随机数生成:在需要生成一定长度的随机数列时,可以使用该功能生成随机…...
Vue3 + Naive-ui Data Table 分页页码显示不全
当使用naive-ui 表格并且使用分页组件的时候 需要增加 remote...
机器学习中的决策阈值
什么是决策阈值? sklearn不允许我们直接设置决策阈值,但它允许我们访问用于进行预测的决策分数(决策函数o/p)。我们可以从决策函数输出中选择最佳得分并将其设置为决策阈值,并且将小于该决策阈值的所有那些决策得分值…...
mongodb导出聚合查询的数据
❗️❗️❗️在正文之前先要讲一个坑,就是mongoexport这个命令工具不支持导出聚合查询的数据,比如通过某某字段来分组 我查了一天关于mongoexport怎么来导出聚合查询的结果集,最终还是gpt给了我答案 😭 既然mongoexport不支持&…...
U-Mail信创邮件系统解决方案
近年来,在国家政策的大力引导和自身数字化转型需求驱动下,国产化成为国内数字化发展道路上的关键词,企业不断加强自主创新能力,进行信创建设,实现软硬件系统国产化替代,已成为大势所趋。邮件系统作为企业管…...
GUI:贪吃蛇
以上是准备工作 Data import javax.swing.*; import java.net.URL;public class Data {public static URL headerURLData.class.getResource("static/header.png");public static ImageIcon header new ImageIcon(headerURL);public static URL upURLData.class.getR…...
leaflet:个性化配置,利用Leaflet-Geoman绘制多种图形(136)
第136个 点击查看专栏目录 本示例的目的是介绍演示如何在vue+leaflet中个性化配置,利用Leaflet-Geoman绘制多种图形。 灵活地配置Leaflet-Geoman的属性,可以产生各种美妙的绘图效果。 直接复制下面的 vue+leaflet源代码,操作2分钟即可运行实现效果 文章目录 示例效果配置方…...
【Shell脚本8】Shell printf 命令
Shell printf 命令 printf 命令模仿 C 程序库(library)里的 printf() 程序。 printf 由 POSIX 标准所定义,因此使用 printf 的脚本比使用 echo 移植性好。 printf 使用引用文本或空格分隔的参数,外面可以在 printf 中使用格式化…...
CSAPP第4章:RISC和CISC指令集
RISC和CISC指令集 IA32被称为复杂指令集计算机(CISC),与精简指令集计算机(RISC)相对。 从历史上看,先出现了CISC机器,计算机不断发展使指令集非常大。 RISC设计理念在80年代早期发展,使用更简单的指令集产生高效的代码。 许多加…...
【LeetCode】每日一题 2023_11_9 逃离火灾(bfs 练习)
文章目录 刷题前唠嗑题目:最长平衡子字符串题目描述代码与解题思路偷看大佬题解 结语 刷题前唠嗑 LeetCode? 启动!!! 嗯?什么?今天是 hard?陷入沉思。。。先看看题吧 题目:最长平…...
flink1.18.0 自适应调度器 资源弹性缩放 flink帮你决定并行度
jobmanager.scheduler Elastic Scaling | Apache Flink 配置文件修改并重启flink后,webui上会显示调整并行度的按钮,他可以自己调整,你也可以通过webUI手动调整: 点击 之后: 调整完成后:...
如何设计vue项目的权限管理?
权限管理的重要性及必要性 数据安全:权限管理可以确保只有具有相应权限的用户能够访问和操作特定的数据。这可以保护敏感数据不被未授权的用户访问,从而提高数据的安全性。功能控制:权限管理可以根据用户的角色和权限设置,控制用户…...
HBase学习笔记(2)—— API使用
对HBase中常用的API操作进行简单的介绍 对应HBase学习笔记(1)—— 知识点总结-CSDN博客中介绍的HBase Shell常用操作 更多用法请参考官网:Apache HBase ™ Reference Guide 依赖导入 <dependencies><dependency><groupId>o…...
C/C++轻量级并发TCP服务器框架Zinx-游戏服务器开发004:游戏核心消息处理 - 玩家类的实现
文章目录 0 代码仓库1 需求2 AOI设计2.1 AOI算法简介2.2 AOI数据结构及实现2.2.1 玩家2.2.2 网格对象2.2.3 游戏世界矩形2.2.4 获取周围玩家的实现2.2.5 代码测试 2.3 GameRole结合AOI创建玩家2.3.1 创建游戏世界全局对象-GameRole继承AOIWorld的Player2.3.2 把玩家到游戏世界的…...
Python Selenium元素定位方法详解
引言 在Web自动化测试中,元素定位是一项非常重要的技术。Python Selenium提供了各种元素定位方法,可以帮助我们定位页面上的元素并与之交互。本文将详细介绍Python Selenium中常用的元素定位方法,并提供实例代码。 1. ID定位 ID是元素在HT…...
分布式事务,你了解多少?(上)
本文主要是讲述分布式事务的理论及常用的技术方案,主要源自各类学习和工作总结,如有不妥之处,还望指正。分布式事务的其他基础请自行查阅资料。 一、分布式事务产生的原因 分布式事务的产生,源自互联网、电商等的发展,…...
深度神经网络贪婪逐层预训练原理与实践
1. 贪婪逐层预训练的本质理解在深度神经网络训练中,贪婪逐层预训练(Greedy Layer-Wise Pretraining)是一种分阶段构建网络参数的策略。我第一次接触这个方法是在2014年处理图像分类任务时,当时面对深层网络难以收敛的问题…...
papers-notebook快速入门:10分钟学会构建自己的论文阅读笔记系统
papers-notebook快速入门:10分钟学会构建自己的论文阅读笔记系统 【免费下载链接】papers-notebook :page_facing_up: :cn: :page_with_curl: 论文阅读笔记(分布式系统、虚拟化、机器学习)Papers Notebook (Distributed System, Virtualizati…...
FuckFuckadblock终极指南:如何彻底告别烦人弹窗和反广告屏蔽
FuckFuckadblock终极指南:如何彻底告别烦人弹窗和反广告屏蔽 【免费下载链接】fuckfuckadblock Filters for blocking mining, pop-ups and anti-adblock bypass. 项目地址: https://gitcode.com/gh_mirrors/fu/fuckfuckadblock FuckFuckadblock是一款强大的…...
Advantech工业连接器国产替代方案与选型实践解析
在工业计算机与嵌入式系统领域,连接器不仅是基础互连器件,更是系统稳定运行的重要保障。Advantech 作为工业计算机行业的代表厂商,其产品广泛应用于工业自动化、智能制造、医疗设备、交通系统及物联网等领域。虽然 Advantech 本身并非传统意义…...
Simulink参数设置避坑指南:get_param/set_param用错?变量和参数对象傻傻分不清?
Simulink参数设置避坑指南:get_param/set_param用错?变量和参数对象傻傻分不清? 在Simulink建模过程中,参数设置看似简单却暗藏玄机。许多工程师在尝试自动化参数配置时,常常陷入性能陷阱、变量作用域混乱或代码生成问…...
健康有益社区慢病智能监测站:破解基层慢病管理瓶颈,践行主动健康
一、慢病防控形势与基层管理瓶颈据国家心血管病中心估算,我国高血压前期人群已超过6亿,10年内进展为高血压的风险超过50%;糖尿病、高血脂、骨质疏松等慢病患病人群同样持续扩大。传统的社区慢病管理依赖人工随访,效率低、覆盖面窄…...
毕设项目 stm32 RFID智能仓库管理系统(源码+硬件+论文)
文章目录 0 前言1 主要功能3 核心软件设计4 实现效果5 最后 0 前言 🔥 这两年开始毕业设计和毕业答辩的要求和难度不断提升,传统的毕设题目缺少创新和亮点,往往达不到毕业答辩的要求,这两年不断有学弟学妹告诉学长自己做的项目系…...
AI试衣算法源码-一键生成模特试衣图-支持多角度+纹理自适应-PHP+MySQL-电商降本增效
温馨提示:文末有资源获取方式电商服装类目卖家都清楚,一套像样的模特试衣图拍摄下来:模特费用:500-2000元/天摄影师灯光:800-3000元/天化妆师场地:500-1500元/天后期修图:20-100元/张一套衣服拍…...
别只盯着ArcGIS了!盘点那些能轻松打开USGS .dem高程数据的冷门神器
超越ArcGIS:五款高效处理USGS DEM数据的专业工具全解析 当大多数GIS从业者遇到USGS的.dem格式高程数据时,第一反应往往是尝试用ArcGIS打开——然后陷入"无效栅格数据"的错误提示中。这种经历揭示了一个行业现状:我们对工具的选择常…...
Go语言零依赖Web框架Kheish:极简设计与高性能路由实现
1. 项目概述:一个轻量级、高性能的Web框架 如果你正在寻找一个能让你快速构建API或Web应用,同时又不想被臃肿的框架和复杂的配置所束缚的工具,那么 graniet/kheish 这个项目很可能就是你的菜。这是一个用Go语言编写的Web框架,它…...
