客户端负载均衡与服务器端负载均衡详解
客户端负载均衡与服务器端负载均衡详解

1. 客户端负载均衡(Client-Side Load Balancing)
核心概念
- 定义:负载均衡逻辑在客户端实现,客户端主动选择目标服务实例。
- 典型场景:微服务内部调用(如Spring Cloud、Dubbo)。
解决方案
| 方案 | 技术栈 | 特点 |
|---|---|---|
| Spring Cloud LoadBalancer | Java | 集成Spring Cloud生态,支持多种算法(轮询、随机、响应时间)。 |
| Dubbo | Java | 原生支持多种策略(轮询、最少活跃连接)。 |
| gRPC | 多语言(Go/Java等) | 内置负载均衡,支持加权轮询和失败重试。 |
| Consul客户端SDK | 多语言 | 通过Consul客户端获取服务实例并选择目标。 |
| AWS SDK | 多语言 | AWS S3等服务的客户端内置负载均衡(选择最近的区域)。 |
2. 服务器端负载均衡(Server-Side Load Balancing)
核心概念
- 定义:负载均衡逻辑在中间层或服务器端实现,客户端只需发送请求到固定地址。
- 典型场景:流量入口层(如API网关、云服务)。
解决方案
| 方案 | 技术栈 | 特点 |
|---|---|---|
| Nginx | C | 高性能七层负载均衡,支持轮询、加权、IP哈希等策略。 |
| HAProxy | C | 四层/七层负载均衡,适合高吞吐场景。 |
| AWS ALB | 云服务 | AWS托管式七层负载均衡,支持自动扩展和健康检查。 |
| Azure Load Balancer | 云服务 | Azure云内负载均衡,支持四层和七层协议。 |
| Kubernetes Service | Kubernetes生态 | 原生服务发现与负载均衡(如ClusterIP、NodePort)。 |
| Istio Envoy | C++(服务网格) | 云原生流量管理,支持高级策略(熔断、重试、蓝绿发布)。 |
3. 对比分析
(1) 核心差异对比表
| 维度 | 客户端负载均衡 | 服务器端负载均衡 |
|---|---|---|
| 实现位置 | 客户端代码中实现 | 服务器或中间层(如Nginx、API网关) |
| 控制点 | 客户端决定目标实例 | 中间层或服务器决定目标实例 |
| 复杂度 | 客户端需维护实例列表和负载策略 | 配置集中,客户端无需关心细节 |
| 延迟 | 可能增加客户端计算开销(选择实例) | 额外跳转到中间层可能增加网络延迟 |
| 扩展性 | 依赖客户端实现 | 中间层可独立扩展(如Nginx集群) |
| 故障恢复 | 客户端需处理实例不可用(如重试、降级) | 中间层自动剔除故障实例 |
| 服务发现 | 依赖客户端与注册中心(如Nacos、Consul) | 中间层直接配置或集成注册中心 |
| 适用场景 | 微服务内部调用、需要细粒度控制 | 流量入口层、高吞吐场景、非微服务架构 |
(2) 详细对比
| 维度 | 客户端负载均衡 | 服务器端负载均衡 |
|---|---|---|
| 优点 | - 灵活性高(自定义策略) - 减少中间层依赖 - 适合动态环境(如云原生) | - 配置集中,客户端简单 - 高性能(C语言实现) - 支持复杂策略(如会话保持) |
| 缺点 | - 客户端复杂度高 - 需维护实例列表 - 可能增加网络跳数 | - 需维护中间层 - 可能成为单点故障(需集群化) - 策略修改需重启中间层 |
| 典型场景 | Spring Cloud、Dubbo、gRPC内部调用 | Nginx入口层、云服务负载均衡、Kubernetes服务发现 |
| 典型协议 | HTTP、gRPC、RPC | HTTP、TCP、UDP |
4. 混合模式(Hybrid Approach)
- 场景:现代架构常结合两者:
- 入口层:Nginx/AWS ALB进行七层负载均衡。
- 微服务内部:Spring Cloud LoadBalancer进行客户端负载。
- 服务网格:Istio同时实现客户端(Envoy Sidecar)和服务器端(全局策略)。
5. 选择建议
| 场景 | 推荐方案 | 理由 |
|---|---|---|
| 微服务内部调用(如Spring Cloud) | 客户端负载均衡(Spring Cloud LoadBalancer) | 灵活集成熔断、服务发现,与生态无缝配合 |
| 高吞吐入口层(如电商、游戏) | 服务器端负载均衡(Nginx/HAProxy) | 高性能、低延迟,支持大规模并发 |
| 云原生架构 | 服务网格(Istio) | 统一控制流量、安全策略、灰度发布 |
| 混合云部署 | AWS ALB + Spring Cloud | 云服务托管负载均衡,客户端控制微服务调用 |
6. 示例代码对比
(1) 客户端负载均衡(Spring Cloud)
// 客户端代码选择实例
@LoadBalanced
private RestTemplate restTemplate;@GetMapping("/users")
public String getUsers() {// restTemplate自动选择user-service实例return restTemplate.getForObject("http://user-service/api/v1/users", String.class);
}
(2) 服务器端负载均衡(Nginx配置)
# Nginx配置分发流量
http {upstream user-service {server 192.168.1.10:8080 weight=2;server 192.168.1.11:8080;server 192.168.1.12:8080 backup;}server {listen 80;location /api/v1/users {proxy_pass http://user-service;}}
}
7. 总结表格
| 维度 | 客户端负载均衡 | 服务器端负载均衡 |
|---|---|---|
| 适用场景 | 微服务内部、动态策略、细粒度控制 | 入口层、高性能、集中管理、传统架构 |
| 性能开销 | 客户端计算实例选择 | 中间层网络跳转 |
| 复杂度 | 客户端复杂,中间层简单 | 客户端简单,中间层复杂 |
| 高可用性 | 依赖客户端实现 | 依赖中间层集群 |
| 典型技术 | Spring Cloud、Dubbo、gRPC | Nginx、AWS ALB、Kubernetes Service、Istio |
8. 注意事项
- 混合模式:大型系统通常结合两者(如API网关+服务网格)。
- 服务发现:客户端方案需与注册中心(如Nacos)配合。
- 云原生趋势:服务网格(Istio)逐渐成为统一解决方案。
- 延迟敏感场景:服务器端负载均衡(如Nginx)更优,因客户端计算可能增加延迟。
相关文章:
客户端负载均衡与服务器端负载均衡详解
客户端负载均衡与服务器端负载均衡详解 1. 客户端负载均衡(Client-Side Load Balancing) 核心概念 定义:负载均衡逻辑在客户端实现,客户端主动选择目标服务实例。典型场景:微服务内部调用(如Spring Cloud…...
vue-element-plus-admin的安装
文档链接:开始 | vue-element-plus-admin 之前尝试按照官方文档来安装,运行npm run dev命令却不能正常打开访问浏览器,换一个方式 首先在目录下打开命令窗口 1、克隆项目 从 GitHub 获取代码 # clone 代码 git clone https://github.com…...
基于springboot的“流浪动物管理系统”的设计与实现(源码+数据库+文档+PPT)
基于springboot的“流浪动物管理系统”的设计与实现(源码数据库文档PPT) 开发语言:Java 数据库:MySQL 技术:springboot 工具:IDEA/Ecilpse、Navicat、Maven 系统展示 系统功能结构图 局部E-R图 系统首页界面 系统…...
爬虫解决debbugger之替换文件
鼠鼠上次做一个网站的时候,遇到的debbugger问题,是通过打断点然后编辑断点解决的,现在鼠鼠又学会了一个新的技能 首先需要大家下载一个reres的插件,这里最好用谷歌浏览器 先请大家看看案例国家水质自动综合监管平台 这里我们只…...
奇怪的电梯——DFS算法
题目 题解 每到一层楼都面临了两种选择:上还是下?因此我们可以定义一个布尔数组用来记录选择。 终止条件其实也明显,要么到了B层,要么没有找到楼层。 如果找到了,选择一个步骤少的方式。又怎么表示没有找到楼层&…...
Open GL ES-> 工厂设计模式包装 SurfaceView + 自定义EGL的OpenGL ES 渲染框架
XML文件 <?xml version"1.0" encoding"utf-8"?> <com.example.myapplication.EGLSurfaceView xmlns:android"http://schemas.android.com/apk/res/android"android:layout_width"match_parent"android:layout_height"…...
2.4goweb加解密和jwt
MD5的基本实现 1. 标准库调用 Go语言通过crypto/md5包提供MD5算法的实现。核心步骤包括: 创建哈希对象:使用md5.New()生成一个实现了hash.Hash接口的实例。写入数据:通过Write()方法或io.WriteString()将数据写入…...
深入解析多表联查(MySQL)
前言 在面试中以及实际开发中,多表联查是每个程序员必备技能,下文通过最简单的学生表和课程表的实例帮大家最快入门多表联查技能。 建立数据表 1. 学生表(students) 创建学生表 CREATE TABLE students (student_id INT AUTO_…...
宇视设备视频平台EasyCVR打造智慧酒店安防体系,筑牢安全防线
一、需求背景 酒店作为人员流动频繁的场所,对安全保障与隐私保护有着极高的要求。为切实维护酒店内部公共区域的安全秩序,24小时不间断视频监控成为必要举措。通常情况下,酒店需在本地部署视频监控系统以供查看,部分连锁酒店还希…...
C++ 编程指南36 - 使用Pimpl模式实现稳定的ABI接口
一:概述 C 的类布局(尤其是私有成员变量)直接影响它的 ABI(应用二进制接口)。如果你在类中添加或修改了私有成员,即使接口不变,编译器生成的二进制布局也会变,从而导致 ABI 不兼容。…...
Linux中的文件传输(附加详细实验案例)
一、实验环境的设置 ①该实验需要两台主机,虚拟机名称为 L2 和 L3 ,在终端分别更改主机名为 node1 和 node2,在实验过程能够更好分辨。 然后再重新打开终端,主机名便都更改了相应的名称。 ②用 ip a 的命令分别查看两个主机的 …...
基于 OpenHarmony 5.0 的星闪轻量型设备应用开发——Ch2 OpenHarmony LiteOS-M 内核应用开发
写在前面: 此篇是系列文章《基于 OpenHarmony5.0 的星闪轻量型设备应用开发》的第 2 章。本篇介绍了如何在 OpenHarmony 5.0 框架下,针对 WS63 进行 LiteOS-M 内核应用工程的开发。 为了方便读者学习,需要OpenHarmony 5.0 WS63 SDK 的小伙伴可…...
论文阅读:2024-arxiv How to Steer LLM Latents for Hallucination Detection?
总目录 大模型安全相关研究:https://blog.csdn.net/WhiffeYF/article/details/142132328 How to Steer LLM Latents for Hallucination Detection? https://arxiv.org/pdf/2503.01917 https://www.doubao.com/chat/2818934852496130 其它资料: https://blog.csdn.net/we…...
Linux--线程概念与控制
目录 1. Linux线程概念 1-1 什么是线程 1-2 分⻚式存储管理 1-2-1 虚拟地址和⻚表的由来 1-2-2 物理内存管理 1-2-3 ⻚表 1-2-4 ⻚⽬录结构 1-2-5 两级⻚表的地址转换 1-2-6 缺⻚异常 1-3 线程的优点 1-4 线程的缺点 1-5 线程异常 1-6 线程⽤途 2. Linux进程VS线…...
Python | kelvin波的水平空间结构
写在前面 简单记录一下之前想画的一个图: 思路 整体比较简单,两个子图,本质上就是一个带有投影,一个不带投影,通常用在EOF的空间模态和时间序列的绘制中,可以看看之前的几个详细的画法。 Python | El Ni…...
【音视频】SDL播放PCM音频
相关API 打开音频设备 int SDLCALL SDL_OpenAudio(SDL_AudioSpec * desired, SDL_AudioSpec * obtained); desired:期望的参数。obtained:实际音频设备的参数,一般情况下设置为NULL即可。 SDL_AudioSpec typedef struct SDL_AudioSpec { i…...
BERT - Bert模型框架复现
本节将实现一个基于Transformer架构的BERT模型。 1. MultiHeadAttention 类 这个类实现了多头自注意力机制(Multi-Head Self-Attention),是Transformer架构的核心部分。 在前几篇文章中均有讲解,直接上代码 class MultiHeadAtt…...
【LeetCode 热题100】二叉树遍历入门:从中序遍历到层序与右视图(力扣94 / 102/199)(Go语言版)
🌳 二叉树遍历入门:从中序遍历到层序与右视图 本文涵盖 LeetCode 上的三道基础但极具代表性的二叉树遍历题: 二叉树的中序遍历 二叉树的层序遍历 二叉树的右视图 通过这些题目,我们将从 DFS 到 BFS,深入理解如何处理…...
docker创建容器添加启动--restart选项
一、通过 Docker 命令直接修改已启动的容器(推荐-已验证) 操作步骤: 1.执行更新命令: docker update --restartalways <容器名或ID>此命令会将容器的重启策略调整为 always(无论容器以何种状态退出࿰…...
一文读懂WPF系列之常用控件以及样式
WPF控件 控件分类概览常用控件常用控件代码示例和效果 样式与模板应用样式定义方式行内样式页面/窗口级资源样式(Local Resource)应用程序全局资源独立资源字典(ResourceDictionary)控件模板(ControlTemplate&…...
嵌入式硬件篇---单片机周期
文章目录 前言 前言 在单片机中,时序控制是其执行指令和协调外设的核心基础。以下是单片机中常见的各种周期及其详细说明,以层次结构展开: 时钟周期(Clock Cycle) 定义: 时钟周期是单片机的最小时间单位&a…...
【双指针】专题:LeetCode 283题解——移动零
移动零 一、题目链接二、题目三、题目解析四、算法原理两个指针的作用以及三个区间总结 五、与快速排序的联系六、编写代码七、时间复杂度、空间复杂度 一、题目链接 移动零 二、题目 三、题目解析 “保持非零元素的相对顺序”,比如,示例1中非零元素1…...
2025蓝桥杯JavaB组
说明 博主自己水平有限,而且答案也不一定对,下面代码和思路仅作分享。我只把我考场上做了的写出来了,有什么问题欢迎评论区交流。 A:逃离高塔 思路: 由于有了去年的经验,所以一上来我就是找规律…...
SQL学习--基础语法学习
SQL和excle对比 学习目标 单表查询 项目背景 SQL 练习环境 SQL Online Compiler - Next gen SQL Editor 商品信息表:https://study-zhibo.oss-cn-shanghai.aliyuncs.com/test/%E5%95%86%E5%93%81%E4%BF%A1%E6%81%AF%E8%A1%A8.csv 订单明细表:https://…...
MATLAB2022b安装
1 从百度网盘下载MATLAB2022b,下载完成后解压到某个文件夹; 链接: MATLAB2022b 提取码: 6666 2 打开解压后的文件夹,进入setup文件夹,双击打开“setup.exe”文件; 3 在弹出窗口中选择“高级选项”-->“我有文件安…...
如何更改OCP与metadb集群的连接方式 —— OceanBase运维管理
背景 许多用户都会借助OCP平台来进行OceanBase集群的运维与监控,且因为考虑单节点的OCP部署,在遇故障时可能会短时间出现无法管控 OceanBase集群,多数用户倾向于采用多节点方式来部署OCP,即 OCP的 metadb集群也是三节点的集群部署…...
HTTP实现心跳模块
HTTP实现心跳模块 使用轻量级的cHTTP库cpp-httplib重现实现HTTP心跳模块 头文件HttplibHeartbeat.h #ifndef HTTPLIB_HEARTBEAT_H #define HTTPLIB_HEARTBEAT_H#include <string> #include <thread> #include <atomic> #include <chrono> #include …...
架构总览怎么写,才算工业级?
📈系统架构文档是整个项目最重要的起点,但很多人第一章就“写穿了”: 不是写得太细,就是没有重点。想要写出高质量、能协作、能传承的架构文档,这一篇会告诉你应该怎么做—— ✅ 架构总览的终极目标 明确边界、定义角色、画清数据流 别讲执行细节,别深入函数调用。 ✅ 架…...
Python10天突击--Day 3:函数式编程突破
以下是 Python 中实现方法耗时统计装饰器的完整方案,包含同步/异步支持、多级嵌套调用统计、可视化输出和性能分析等高级功能: 基础版:同步方法计时装饰器 import time from functools import wrapsdef timeit(func):"""基础…...
Datawhale 入驻 GitCode:以开源力量推动 AI 教育公平与创新
在 AI 技术深度重塑教育生态的今天,国内首个 AI 开源学习社区 —— Datawhale 正式加入 GitCode 开源平台!作为覆盖全球 3000 高校、培养超百万 AI 人才的创新社区,Datawhale 将通过开源协作模式,为人工智能教育公平注入新动能&a…...
