关于 微服务负载均衡 的详细说明,涵盖主流框架/解决方案的对比、核心功能、配置示例及总结表格
以下是关于 微服务负载均衡 的详细说明,涵盖主流框架/解决方案的对比、核心功能、配置示例及总结表格:
1. 负载均衡的核心概念
负载均衡在微服务中用于将请求分发到多个服务实例,以实现:
- 高可用性:避免单点故障。
- 性能优化:均衡流量,避免热点。
- 动态扩展:支持服务实例的动态增减。
常见负载均衡策略:
- 轮询(Round Robin):按顺序分配请求。
- 随机(Random):随机选择实例。
- 加权轮询(Weighted Round Robin):根据实例权重分配流量。
- 最少连接(Least Connections):优先分配到连接数最少的实例。
- IP哈希(IP Hash):根据客户端 IP 分配,保证会话粘性。
2. 主流负载均衡框架/解决方案对比
2.1 Spring Cloud LoadBalancer
特点:
- Spring Cloud 生态核心组件:替代 Ribbon,与 Spring Cloud Alibaba 等集成。
- 灵活扩展:支持多种策略(轮询、随机等)。
- 轻量级:依赖服务注册发现组件(如 Nacos/Eureka)。
配置示例:
# application.yml(以 Nacos 为例)
spring:application:name: order-servicecloud:nacos:discovery:server-addr: 127.0.0.1:8848loadbalancer:ribbon:enabled: false # 禁用 Ribbon,启用 Spring Cloud LoadBalancer
服务调用示例:
// 使用 RestTemplate 调用服务
@Autowired
private LoadBalancerClient loadBalancer;public User getUser() {ServiceInstance instance = loadBalancer.choose("user-service");return restTemplate.getForObject(instance.getUri() + "/users/1", User.class);
}
2.2 Nacos 内置负载均衡
特点:
- 与注册中心深度集成:基于 Nacos 的服务发现实现。
- 策略灵活:支持轮询、随机、权重等。
- 动态更新:实例变化实时生效。
配置示例:
# application.yml
spring:cloud:nacos:discovery:server-addr: 127.0.0.1:8848loadbalancer:nacos:enabled: true # 启用 Nacos 负载均衡
2.3 Consul + Spring Cloud
特点:
- 基于 Consul 的服务发现:支持多数据中心负载均衡。
- 策略扩展:通过 Spring Cloud LoadBalancer 集成。
配置示例:
# application.yml
spring:cloud:consul:discovery:enabled: truehealth-check-path: /actuator/healthloadbalancer:consul:enabled: true
2.4 Dubbo 负载均衡
特点:
- 高性能:Dubbo 内置多种策略(轮询、随机、最少活跃调用等)。
- 与注册中心解耦:支持 ZooKeeper/Nacos 作为注册中心。
配置示例:
# dubbo-provider.yml
dubbo:protocol:name: dubboport: 20880registry:address: nacos://127.0.0.1:8848loadbalance: roundrobin # 指定轮询策略
2.5 Istio/Envoy
特点:
- 服务网格方案:非侵入式,通过 Sidecar 实现。
- 高级策略:支持加权轮询、故障注入、金丝雀发布。
- 多语言支持:适合混合语言微服务。
配置示例(Istio VirtualService):
apiVersion: networking.istio.io/v1alpha3
kind: VirtualService
metadata:name: user-service
spec:hosts:- "user-service"http:- route:- destination:host: user-servicesubset: v1weight: 90- destination:host: user-servicesubset: v2weight: 10loadBalancer:simple: ROUND_ROBIN
2.6 Kubernetes Service
特点:
- 基于 DNS/IP 的负载均衡:通过 ClusterIP 或 Ingress 实现。
- 内置策略:轮询、最少连接等。
- 云原生集成:与 Kubernetes 生态深度集成。
配置示例(Kubernetes Service):
apiVersion: v1
kind: Service
metadata:name: user-service
spec:ports:- port: 80targetPort: 8080selector:app: user-servicetype: ClusterIP
2.7 AWS ALB/NLB
特点:
- 云原生托管服务:AWS 提供的负载均衡器。
- 高可用性:支持跨 AZ 的流量分发。
- 集成丰富:与 AWS ECS、Lambda 等无缝集成。
配置示例(AWS ALB):
# 创建 ALB 并关联目标组
aws elbv2 create-load-balancer --name my-alb --subnets subnet-123 subnet-456
aws elbv2 create-target-group --name my-target-group --protocol HTTP --port 8080 --vpc-id vpc-789
aws elbv2 register-targets --target-group-arn arn:aws:... --targets i-0123456789
aws elbv2 create-listener --load-balancer-arn arn:aws:... --protocol HTTP --port 80 --default-actions Type=forward,TargetGroupArn=arn:aws:...
2.8 HashiCorp Consul Connect
特点:
- 服务网格方案:基于 Consul 的服务网格。
- 安全策略:支持 mTLS 加密。
- 动态配置:通过 Consul UI 管理流量规则。
配置示例(Consul Connect):
# Consul 服务配置
service {name = "user-service"connect {sidecar_service {}}
}
2.9 Ribbon(已逐步淘汰)
特点:
- Spring Cloud 历史组件:支持多种策略(轮询、随机、带权重等)。
- 维护状态:Spring Cloud 已推荐使用 LoadBalancer 替代。
配置示例:
# application.yml
spring:cloud:loadbalancer:ribbon:enabled: true
2.10 Apache Dubbo 自定义负载均衡
特点:
- 可插拔策略:支持自定义负载均衡算法。
- 高性能:适合高并发场景。
自定义策略示例:
@Component
public class CustomLoadBalance implements LoadBalance {@Overridepublic Invoker<?> select(Invocation inv, List<Invoker<?>> invokers) {// 实现自定义逻辑,如加权轮询return invokers.get(new Random().nextInt(invokers.size()));}
}
3. 核心功能对比表格
框架/方案 | 负载均衡策略 | 依赖组件 | 配置复杂度 | 非侵入性 | 多语言支持 | 适用场景 |
---|---|---|---|---|---|---|
Spring Cloud LoadBalancer | 轮询、随机、响应式 | Eureka/Nacos/Consul | 低 | 部分侵入式 | 有限 | Spring Cloud 生态,Java 服务 |
Nacos 内置负载均衡 | 轮询、随机、权重 | Nacos 注册中心 | 低 | 部分侵入式 | 有限 | 阿里云生态,需 Nacos 支持 |
Consul + Spring Cloud | 轮询、随机 | Consul | 中等 | 部分侵入式 | 有限 | 需 Consul 注册中心 |
Dubbo | 轮询、随机、最少活跃调用 | ZooKeeper/Nacos | 低 | 部分侵入式 | 有限 | 高性能 Java 微服务架构 |
Istio/Envoy | 轮询、加权轮询、环状 | Istio 控制平面 | 高 | 非侵入式 | 完全支持 | 多语言微服务,需服务网格支持 |
Kubernetes Service | 轮询、最少连接 | Kubernetes | 低 | 非侵入式 | 完全支持 | 容器化部署,云原生架构 |
AWS ALB/NLB | 轮询、IP哈希、加权 | AWS 云服务 | 中等 | 非侵入式 | 完全支持 | AWS 云环境,托管服务需求 |
Consul Connect | 轮询、随机 | Consul | 中等 | 非侵入式 | 有限 | 需 Consul 服务网格支持 |
4. 关键功能与实现
4.1 轮询(Round Robin)
- Spring Cloud LoadBalancer:默认策略,按顺序分配请求。
- Kubernetes Service:基于 DNS 或 IP 的轮询。
4.2 加权轮询(Weighted Round Robin)
- Istio:通过
VirtualService
配置权重:apiVersion: networking.istio.io/v1alpha3 kind: VirtualService spec:http:- route:- destination: { host: user-service, subset: v1 }weight: 80- destination: { host: user-service, subset: v2 }weight: 20
4.3 基于响应时间的负载均衡
- Nacos:根据实例健康状态和响应时间动态调整权重。
- Dubbo:通过
LeastActive
策略选择活跃调用最少的实例。
4.4 会话保持(Session Affinity)
- Kubernetes:通过
Session Affinity
配置:apiVersion: v1 kind: Service spec:sessionAffinity: ClientIP
4.5 动态权重调整
- Istio:实时调整流量权重,支持金丝雀发布:
apiVersion: networking.istio.io/v1alpha3 kind: DestinationRule spec:trafficPolicy:loadBalancer:simple: ROUND_ROBINsubsets:- name: v1labels: { version: v1 }- name: v2labels: { version: v2 }
5. 典型场景代码示例
5.1 Spring Cloud LoadBalancer
// 使用 RestTemplate 调用服务
@Bean
@LoadBalanced
public RestTemplate restTemplate() {return new RestTemplate();
}// 调用示例
public User getUser() {return restTemplate.getForObject("http://user-service/users/1", User.class);
}
5.2 Istio 负载均衡
# VirtualService 配置金丝雀发布
apiVersion: networking.istio.io/v1alpha3
kind: VirtualService
metadata:name: user-service
spec:hosts:- "user-service"http:- route:- destination:host: user-servicesubset: v1weight: 90- destination:host: user-servicesubset: v2weight: 10
5.3 Dubbo 负载均衡
# dubbo-provider.yml
dubbo:protocol:name: dubboport: 20880registry:address: nacos://127.0.0.1:8848loadbalance: roundrobin
6. 功能对比总结
方案 | 负载均衡策略支持 | 健康检查集成 | 动态权重 | 会话保持 | 配置方式 | 适用场景 |
---|---|---|---|---|---|---|
Spring Cloud LoadBalancer | 基础策略 | 支持 | 支持(需配置) | 支持 | YAML/Java Config | Spring Cloud 生态,Java 微服务 |
Nacos | 轮询、随机、权重 | 内置 | 支持 | 支持 | Nacos 控制台/YAML | 阿里云生态,需 Nacos 支持 |
Istio/Envoy | 多种策略(环状、加权) | 内置 | 实时调整 | 支持 | Istio CRD | 多语言微服务,需服务网格支持 |
Kubernetes Service | 轮询、最少连接 | 内置 | 不支持 | 支持 | Kubernetes YAML | 容器化部署,简单场景 |
AWS ALB/NLB | AWS 原生策略 | AWS 监控 | 支持 | 支持 | AWS 控制台/CloudFormation | AWS 云环境,托管服务需求 |
Dubbo | 多种策略(轮询、随机等) | 内置 | 支持 | 支持 | Dubbo 配置文件 | 高性能 Java 微服务架构 |
7. 选择建议
需求场景 | 推荐方案 | 原因 |
---|---|---|
Spring Cloud 生态 | Spring Cloud LoadBalancer | 与 Eureka/Nacos 深度集成,简单易用。 |
多语言微服务 | Istio/Envoy | 非侵入式,支持高级策略如金丝雀发布。 |
容器化部署(Kubernetes) | Kubernetes Service 或 Istio | Kubernetes 原生支持,或 Istio 提供更复杂的流量管理。 |
高性能 Java 服务 | Dubbo | 轻量级,支持自定义策略,与 Nacos 集成。 |
云原生托管服务 | AWS ALB 或 Azure Load Balancer | 托管服务,与云平台深度集成,维护成本低。 |
8. 注意事项
- Spring Cloud LoadBalancer:需结合注册中心(如 Nacos)使用,避免使用已淘汰的 Ribbon。
- Istio:需部署 Sidecar,适合复杂流量管理场景。
- Kubernetes Service:简单场景足够,复杂需求需结合 Istio。
- Dubbo:需自行实现健康检查或依赖注册中心。
9. 总结表格
方案 | 性能 | 策略灵活性 | 配置复杂度 | 非侵入性 | 适用场景 |
---|---|---|---|---|---|
Spring Cloud LoadBalancer | 中等 | 高(可扩展) | 低 | 部分侵入式 | Spring Cloud 生态,Java 微服务 |
Nacos | 高 | 高 | 中等 | 部分侵入式 | 阿里云生态,需 Nacos 支持 |
Istio/Envoy | 高 | 极高 | 高 | 非侵入式 | 多语言微服务,需服务网格支持 |
Kubernetes Service | 极高 | 低(基础策略) | 低 | 非侵入式 | 容器化部署,简单场景 |
AWS ALB/NLB | 极高 | 高 | 中等 | 非侵入式 | AWS 云环境,托管服务需求 |
Dubbo | 极高 | 高 | 低 | 部分侵入式 | 高性能 Java 微服务架构 |
10. 典型错误与解决方案
问题 | 原因 | 解决方案 |
---|---|---|
流量未均匀分配 | 策略配置错误或实例权重未设置 | 检查策略配置(如 Istio 的 VirtualService 权重)或 Dubbo 的 loadbalance 参数。 |
服务实例未及时剔除 | 健康检查配置不正确 | 确保健康检查路径(如 /actuator/health )和超时时间合理。 |
跨数据中心流量不均衡 | 多数据中心策略未配置 | 在 Nacos/Consul 中配置多区域权重,或使用 Istio 的多集群策略。 |
通过以上对比,开发者可根据技术栈和需求选择合适的负载均衡方案。对于云原生环境,Istio 或 Kubernetes Service 是优选;Spring Cloud 项目推荐 Spring Cloud LoadBalancer;高性能场景可考虑 Dubbo 或 Nacos。
相关文章:
关于 微服务负载均衡 的详细说明,涵盖主流框架/解决方案的对比、核心功能、配置示例及总结表格
以下是关于 微服务负载均衡 的详细说明,涵盖主流框架/解决方案的对比、核心功能、配置示例及总结表格: 1. 负载均衡的核心概念 负载均衡在微服务中用于将请求分发到多个服务实例,以实现: 高可用性:避免单点故障。性…...
【AI提示词】API开发专家
提示说明 API开发专家专注于设计和实现高效、稳定、安全的应用程序接口(API)。他们通过深入理解业务需求和用户场景,为用户提供定制化的API解决方案。 提示词 # 角色 API开发专家## 注意 1. 专家设计应考虑API开发过程中的技术细节和用户需…...
Node.js中http模块详解
Node.js 中 http 模块全部 API 详解 Node.js 的 http 模块提供了创建 HTTP 服务器和客户端的功能。以下是 http 模块的所有 API 详解: 1. 创建 HTTP 服务器 const http require(http);// 1. 基本服务器 const server http.createServer((req, res) > {res.w…...
uniapp中,使用plus.io实现安卓端写入文件
这段代码是要删除的,留在这里避免以后用到。 在我写流式语音接收与播放的时候,写到这里无法继续了,因为播放时总是出错,无法播放,因为audioContext.play()不支持 但是,我写的这些,用于写入文件是…...
Linux xorg-server 解析(二)- 如何调试 xorg-server
一:概述 Xorg-server简称Xorg,它是Linux窗口系统的核心组件,它是用户态应用程序,但它的调试方法和普通用户态应用程序有所不同,因为Xorg是系统的核心组件,负责图形显示和输入设备的管理,所以在单台机器上调试Xorg可能会面临一些困难和限制,如果在同一台机器上调试它,可…...
CFS 调度器两种调度类型普通调度 和 组调度
在 Linux 的 CFS(Completely Fair Scheduler) 调度器中,确实存在两种调度类型:普通调度 和 组调度。这两种调度类型分别适用于不同的场景,并通过三个关键维度(权重、抢占优先级、最大配额)来影响…...
「逻辑推理」AtCoder AT_abc401_d D - Logical Filling
前言 这次的 D 题出得很好,不仅融合了数学逻辑推理的知识,还有很多细节值得反复思考。虽然通过人数远高于 E,但是通过率甚至不到 60%,可见这些细节正是出题人的侧重点。 题目大意 给定一个长度为 N N N 的字符串 S S S&#…...
PyTorch 深度学习实战(36):混合精度训练与梯度缩放
在上一篇文章中,我们探讨了图生成模型与分子设计。本文将深入介绍混合精度训练(Mixed Precision Training)和梯度缩放(Gradient Scaling)技术,这些技术可以显著加速模型训练并减少显存占用,同时…...
【Flink运行时架构】组件构成
在Flink的运行架构中,有两大比较重要的组件:作业管理器(JobManager)和任务管理器(TaskManager)。 Flink的作业提交与任务处理时的系统如下图所示。 其中,客户端并不是处理系统的一部分ÿ…...
simpy仿真
一共5个顾客,2个服务台 import simpy import randomdef customer(env, name, service_time_mean):arrival_time env.nowprint(f{arrival_time}: {name} 到达服务台,开始排队)with server.request() as req:yield reqwait_time env.now - arrival_time…...
Docker 安装MySQL
一键启动 docker run -d \--name mysql \-p 3306:3306 \-e TZAsia/Shanghai \-e MYSQL_ROOT_PASSWORD1234 \-v /usr/local/mysql/data:/var/lib/mysql \-v /usr/local/mysql/conf:/etc/mysql/conf.d \--restart always --name mysql \mysql 检查是否启动 docker ps 本地连接测…...
【消息队列kafka_中间件】三、Kafka 打造极致高效的消息处理系统
在当今数字化时代,数据量呈爆炸式增长,实时数据处理的需求变得愈发迫切。Kafka 作为一款高性能、分布式的消息队列系统,在众多企业级应用中得到了广泛应用。然而,要充分发挥 Kafka 的潜力,实现极致高效的消息处理&…...
conda如何安装和运行jupyter
在Conda环境中安装和运行Jupyter Notebook是一项常见且实用的任务,特别是在数据科学和机器学习项目中。以下是使用Conda安装和运行Jupyter Notebook的步骤: 安装Jupyter Notebook 首先,确保你的Conda是最新的。打开终端或Anaconda Prompt&a…...
防爆平板:石油化工厂智慧转型的“中枢神经”
易燃易爆气体、高温高压环境、复杂设备集群,这些特性使得传统电子设备难以直接融入生产流程。而防爆平板的出现,不仅打破了这一技术壁垒,更通过智能化、模块化设计,逐步成为连接人、设备与数据的“中枢神经”,推动石油…...
遨游科普:三防平板可以实现哪些功能?
在现代工业与户外作业场景中,电子设备不仅要面对极端环境的考验,更要承担起高效协同生产的重任。三防平板作为“危、急、特”场景移动终端的代表性产品,其核心价值早已超越传统消费级设备的范畴,成为连接智慧生产与安全管理的重要…...
互联网三高-数据库高并发之分库分表
1 数据库概述 1.1 数据库本身的瓶颈 ① 连接数 MySQL默认最大连接数为100,允许的最大连接数为16384 ② 单表海量数据查询性能 单表最好500w左右,最大警戒线800w ③ 单数据库并发压力问题 MySQL QPS:1500左右/秒 ④ 系统磁盘IO、CPU瓶颈 1.2 数…...
Python----机器学习(基于贝叶斯的鸢尾花分类)
贝叶斯方法是一种统计推断的 方法,它利用贝叶斯定理来更新我们对事件概率的信念。这种方法在机器学习和数据 分析中得到广泛应用,特别是在分类和概率估计问题上。 一、数据集介绍 这是分类方法文献中最早使用的数据集之一,广泛用于统计和机器…...
问题 | 对于初学者来说,esp32和stm32哪个比较适合?
对于初学者选择ESP32还是STM32入门嵌入式开发,需综合考虑学习目标、兴趣方向及未来职业规划。以下是两者的对比分析及建议: 1. 适合初学者的关键因素 ESP32的优势 内置无线通信:集成Wi-Fi和蓝牙功能,无需额外模块即可开发物联网…...
org.apache.spark.SparkException: Kryo serialization failed: Buffer overflow...
Spark异常:Kryo serialization failed: Buffer overflow. 1、问题描述 SparkSQL任务报错如下: org.apache.spark.SparkException: Kryo serialization failed: Buffer overflow. Available: 0, required: xxx. To avoid this, increase spark.kryoseri…...
webpack vite
1、webpack webpack打包工具(重点在于配置和使用,原理并不高优。只在开发环境应用,不在线上环境运行),压缩整合代码,让网页加载更快。 前端代码为什么要进行构建和打包? 体积更好&#x…...
论文笔记——KIMI-VL:具有增强推理能力的有效开源视觉语言模型
KIMI-VL:具有增强推理能力的有效开源视觉语言模型 原文地址:https://arxiv.org/pdf/2504.07491v1 开源地址:https://github.com/MoonshotAI/Kimi-VL 目录 简介架构概述训练方法主要功能性能基准通过长链思考增强推理应用结论 简介 视觉…...
大模型蒸馏-小模型超进化
👏作者简介:大家好,我是爱吃芝士的土豆倪,24届校招生Java选手,很高兴认识大家📕系列专栏:Spring原理、JUC原理、Kafka原理、分布式技术原理、数据库技术、JVM原理、AI应用🔥如果感觉…...
辅助记忆数字和唱名的小工具【仅PC端】
通过网盘分享的文件:random_music_note.exe 链接: https://pan.baidu.com/s/1Akc2gPzAcyhEfPHlbOYLXw?pwd4fua 提取码: 4fua –来自百度网盘超级会员v7的分享...
Android 知识沉淀
注解 1.枚举类型传参优化 enum WeekDay{SUNDAY, MONDAY}public static void setDay(WeekDay day){}我们已知,枚举类型是一个对象,对象占用的空间较大,有 12 个对象头对象的数据部分8 字节对齐,所以这里可以利用注解优化ÿ…...
KiActivateWaiterQueue函数和Queue->Header.WaitListHead队列等待列表的关系
第一部分: if (Thread->ApcState.KernelApcPending && (Thread->SpecialApcDisable 0) && (Thread->WaitIrql < APC_LEVEL)) { } else { // // Insert wait block in ob…...
代码学习总结(一)
代码学习总结(一) 这个系列的博客是记录下自己学习代码的历程,有来自平台上的,有来自笔试题回忆的,主要基于 C 语言,包括题目内容,代码实现,思路,并会注明题目难度&…...
设计模式 --- 策略模式
策略模式(Strategy Pattern)是一种 行为型设计模式,用于动态切换算法或策略,使得算法可以独立于客户端变化。它通过封装算法策略并使其可互换,提升了系统的灵活性和扩展性,尤其适用于需要多种…...
c++进阶之----智能指针
1.概念 在 C 中,智能指针是一种特殊的指针类型,它封装了裸指针(raw pointer)的行为,并通过 RAII(Resource Acquisition Is Initialization,资源获取即初始化)机制自动管理动态分配的…...
08-JVM 面试题-mk
1.JVM 的各部分组成 知道JVM 的好处:知道java 运行机制,排查问题的能力增加,比如内存泄漏、CPU飙高 JVM 是什么:Java Virtual Machine缩写,Java程序的运行环境(java二进制字节码的运行环境) 好处: 一次编写,到处运行自动内存管理,垃圾回收机制从图中可以看出 JVM …...
MTK7628基于原厂的mtk-openwrt-sdk-20160324-8f8e4f1e.tar.bz2 源代码包,配置成单网口模式的方法
一、配置. 在SDK工程下,运行make kernel_menuconfig,如下图所示: Ralink Module --->选上“One Port Only”,如下图所示: 如果P0网口实现WAN口,就配置成W/LLLL,否则就配置成LLLL/W. 二、修改网口的原代…...
青少年编程与数学 02-016 Python数据结构与算法 15课题、字符串匹配
青少年编程与数学 02-016 Python数据结构与算法 15课题、字符串匹配 一、字符串匹配问题的基本概念(一)定义(二)术语 二、暴力匹配算法(Naive String Matching)(一)算法逻辑…...
基础层数据从kafka读取写入hbase的优化方案
背景: 上游kafka的topic只有一个分区,所以spark在消费的时候,无论设置的executor数有多少,最终只有一个executor在执行,如果不指定executor num的话,默认是开启两个executor,有一个executor的资源是浪费的,例如下面显示的情况,其实只有一个executor是active的状态. 在消费的时…...
thingsboard3.9.1编译问题处理
问题1: [ERROR] Failed to execute goal org.thingsboard:gradle-maven-plugin:1.0.12:invoke (default) on project http: Execution default of goal org.thingsboard:gradle-maven-plugin:1.0.12:invoke failed: Plugin org.thingsboard:gradle-maven-plugin:1.…...
Adobe Photoshop 2025 Mac中文 Ps图像编辑
Adobe Photoshop 2025 Mac中文 Ps图像编辑 一、介绍 Adobe Photoshop 2025 Mac版集成了多种强大的图像编辑、处理和创作功能。①强化了Adobe Sensei AI的应用,通过智能抠图、自动修复、图像生成等功能,用户能够快速而精确地编辑图像。②3D编辑和动画功…...
什么是VLA
视觉-语言-动作(VLA)技术综述:迈向具身智能的未来 1. 引言 随着人工智能从单一模态感知迈向多模态交互,视觉-语言-动作(Vision-Language-Action, VLA) 技术逐渐成为连接感知、推理与物理行动的核心桥梁。V…...
数据结构:C语言版严蔚敏和解析介绍,附pdf
《数据结构:C语言版(第2版)》严蔚敏李冬梅吴伟民.pdf 《数据结构:C语言版》严蔚敏,李冬梅.pdf 《数据结构C语言第2版习题解析与实验指导》李冬梅.pdf 「《数据结构:C语言版(第2版 )》…...
C++线段树详解与实现技巧
📚 C++线段树详解与实现技巧 线段树(Segment Tree)是一种高效处理 区间查询 和 区间更新 的数据结构,时间复杂度为 O(log n)。本文结合代码实例,详解其核心原理与实现细节。 🌳 线段树结构特点 完全二叉树:使用数组存储,父子节点关系通过下标计算。区间划分:每个节…...
202527 | RabbitMQ-基础 | 队列 | Direct + Fanout + Topic 交换机 | 消息转换器
RabbitMQ RabbitMQ 架构与核心概念详解 一、整体架构图 #mermaid-svg-UTlKmvHL7RNWK6vu {font-family:"trebuchet ms",verdana,arial,sans-serif;font-size:16px;fill:#333;}#mermaid-svg-UTlKmvHL7RNWK6vu .error-icon{fill:#552222;}#mermaid-svg-UTlKmvHL7RNWK6v…...
【学习笔记】服务器上使用 nbconvert 将 Jupyter Notebook 转换为 PDF
1. 环境准备:安装必要工具 在服务器终端运行以下命令,确保依赖已安装: (1) 安装 nbconvert 和 pandoc pip install nbconvert pandoc (2) 安装 LaTeX(推荐 TeX Live) # Ubuntu/Debian sudo apt-get update sudo a…...
List、Set集合通过Stream流求和
目录 一、泛型为Integer、Long、Double、BigDecimal求和 二、泛型为实体类 对单个属性求和 对多个属性分别分组求和 并返回聚合后的对象 多字段乘积求和(基本数据类型) 多字段乘积求和(BigDecimal) 对对象中的多个字段求和…...
微软VSCode 能否击败 Cursor 和 Windsurf?
微软是否能利用平台优势和许可限制来阻止竞争对手? AI 代码编辑器之战加剧 蓬勃发展的 AI 代码编辑领域竞争日益激烈,这个最具变革性和盈利性的新技术领域正在适应相互间的竞争。Visual Studio Code 目前是最主导的代码编辑器。 “根据 Stack Overflow 调查,Visual Studi…...
VSCode会击败Cursor和Windsurf吗?
VSCode 会击败 Cursor 和 Windsurf 吗?微软能不能靠自己的地盘优势和规则限制打压对手?答案是"能",但他们真的会这么干吗? Cursor & Windsurf vs VSCode Copilot 大PKAI编程工具大战越来越激烈现在最火最赚钱的AI…...
机器学习(4)—— K近邻算法
文章目录 1. K近邻算法(K-Nearest Neighbors, KNN)原理1.1. K近邻算法是什么算法?1.2. 核心思想 2. K近邻算法的步骤2.1. 选择K值2.2. 计算距离2.3. 选择最近邻:2.4. 做出预测: 3. K值的选择4. 数据标准化5. 优缺点6. …...
深入解读 React 纯组件(PureComponent)
什么是纯组件? React 的纯组件(PureComponent)是 React.Component 的一个变体,它通过浅比较(shallow comparison)props 和 state 来自动实现 shouldComponentUpdate() 方法,从而优化性能。 核心特点 1. 自动浅比较: PureCompon…...
常见MQ及类MQ对比:Redis Stream、Redis Pub/Sub、RocketMQ、Kafka 和 RabbitMQ
常见MQ及类MQ对比 基于Grok调研 Redis Stream、Redis Pub/Sub、RocketMQ、Kafka 和 RabbitMQ 关键点: Redis Pub/Sub 适合简单实时消息,但不持久化,消息可能丢失。Redis Stream 提供持久化,适合需要消息历史的场景,但…...
202528 | RabbitMQ-高级 | 消息可靠性 | 业务幂等性 | 延迟消息
消息可靠性 RabbitMQ发送者可靠性 一、发送者重连机制 #mermaid-svg-gqr6Yr5UNZX87ZDU {font-family:"trebuchet ms",verdana,arial,sans-serif;font-size:16px;fill:#333;}#mermaid-svg-gqr6Yr5UNZX87ZDU .error-icon{fill:#552222;}#mermaid-svg-gqr6Yr5UNZX87ZD…...
Java EE期末总结(第六章)
一、IoC 1、Bean装配流程 IOC装配流程在代码中的对应就体现在Service这个注解 依赖注入在代码中体现在 ,比如 Resource UserService userService 二、AOP 简化流程,为程序员简便操作 tmd编不下去了我自己看视频都没理解md不弄了; 给两个…...
ASP.NET Core 性能优化:内存缓存
文章目录 前言一、什么是缓存二、内存缓存三、使用内存缓存1)注册内存缓存服务2)注入与基本使用3)高级用法GetOrCreate(避免缓存穿透)异步方法:GetOrCreateAsync(避免缓存穿透)两种过…...
Go小技巧易错点100例(二十六)
本期分享: 1. string转[]byte是否会发生内存拷贝 2. Go程序获取文件的哈希值 正文: string转[]byte是否会发生内存拷贝 在Go语言中,字符串转换为字节数组([]byte)确实会发生内存拷贝。这是因为在Go中,字…...
《算法笔记》3.5小节——入门模拟->进制转换
1022 D进制的AB #include <iostream> using namespace std; int maxn32;int main() {int z[maxn],num0,a,b,d;cin>>a>>b>>d;int resab;do{z[num]res%d;resres/d;}while(res);for (int i num-1; i >0 ; i--) {cout<<z[i];}return 0; }问题 A:…...