当前位置: 首页 > article >正文

用Nginx实现负载均衡与高可用架构(整合Keepalived)

前言

在分布式架构中,负载均衡高可用是保障系统稳定性的两大核心能力。本文将深入讲解如何通过Nginx实现七层负载均衡,并结合Keepalived构建无单点故障的高可用架构。文末附完整配置模板!


一、Nginx负载均衡实现方案

1. 核心原理

Nginx通过反向代理将客户端请求分发到多个后端服务器,基于Upstream模块实现流量调度,支持多种负载算法。

2. 基础配置模板
http {upstream backend {# 默认轮询算法server 192.168.1.101:80 weight=5;  # 权重配置server 192.168.1.102:80 max_fails=3 fail_timeout=30s; # 健康检查server 192.168.1.103:80 backup;    # 备用节点}server {listen 80;location / {proxy_pass http://backend;}}
}
3. 负载均衡算法对比
算法配置指令适用场景特点
轮询(默认)默认通用场景简单公平,支持权重
最少连接least_conn长连接服务(如数据库)动态分配,资源利用率高
IP哈希ip_hash会话保持需求固定用户->服务器映射
一致性哈希hash $key缓存服务器集群减少缓存击穿
4. 高级功能实现
  • 健康检查(被动模式):
    server 192.168.1.102 max_fails=3 fail_timeout=30s;
    
  • 流量分割(灰度发布):
    upstream backend {server 192.168.1.101 weight=90;  # 90%流量到新版本server 192.168.1.102 weight=10;  # 10%流量到旧版本
    }
    

二、Nginx高可用架构(Keepalived方案)

1. 架构原理

通过VRRP协议实现虚拟IP(VIP)漂移,主备节点自动切换,保障服务不间断。

2. 环境准备
  • 两台Nginx服务器(主:192.168.1.101,备:192.168.1.102)
  • 虚拟IP:192.168.1.100(对外暴露的统一入口)
3. Keepalived配置详解

主节点配置(/etc/keepalived/keepalived.conf):

global_defs {router_id nginx_master  # 标识节点名称
}vrrp_script chk_nginx {script "/etc/keepalived/check_nginx.sh"  # 健康检查脚本interval 2weight -20   # 检测失败时降低优先级
}vrrp_instance VI_1 {state MASTER            # 初始状态interface eth0          # 物理网卡名称virtual_router_id 51    # 集群ID(必须一致)priority 100            # 初始优先级(主>备)advert_int 1            # 心跳间隔authentication {        # 认证配置auth_type PASSauth_pass 1111}virtual_ipaddress {192.168.1.100/24    # 虚拟IP}track_script {          # 绑定健康检查chk_nginx}
}

备节点配置(仅不同部分):

state BACKUP     # 设置为备用
priority 90      # 优先级低于主节点
4. 健康检查脚本

创建 /etc/keepalived/check_nginx.sh

#!/bin/bash
# 检测Nginx进程是否存在
if ! pgrep -x "nginx" > /dev/null; thensystemctl restart nginx || exit 1  # 尝试重启,失败则返回1
fi
# 可选:HTTP状态检测
curl -s http://localhost/health > /dev/null || exit 1

赋予执行权限:

chmod +x /etc/keepalived/check_nginx.sh
5. 启动与验证
systemctl start keepalived   # 启动服务
systemctl enable keepalived  # 设置开机自启

查看VIP绑定:

ip addr show eth0 | grep 192.168.1.100

三、高级优化方案

1. 双主模式(Active-Active)
# 节点1额外配置
vrrp_instance VI_2 {state MASTERvirtual_router_id 52priority 100virtual_ipaddress { 192.168.1.101/24 }
}# 节点2额外配置
vrrp_instance VI_2 {state BACKUPvirtual_router_id 52priority 90virtual_ipaddress { 192.168.1.101/24 }
}
2. 结合DNS轮询
  • 将多个VIP绑定到同一个域名
  • 实现多级负载均衡(DNS层+Nginx层)
3. 监控告警集成
  • Prometheus监控指标:
    # 安装nginx_exporter
    location /stub_status {stub_status;allow 127.0.0.1;deny all;
    }
    

四、常见问题与解决方案

问题现象排查步骤解决方案
VIP不漂移1. 检查防火墙是否允许VRRP协议
2. 查看keepalived日志
开放IP协议号112
脑裂(双主)1. 检查网络连通性
2. 确认virtual_router_id唯一
配置不同的router_id
健康检查误判1. 检查脚本执行权限
2. 增加curl超时设置
优化检测逻辑

总结

通过Nginx实现负载均衡可提升系统吞吐量,而结合Keepalived的高可用方案能确保服务零中断。实际部署时需注意:

  1. 根据业务场景选择合适的负载算法
  2. VIP需与物理网络在同一子网
  3. 生产环境建议使用双主+健康检查增强模式

相关文章:

用Nginx实现负载均衡与高可用架构(整合Keepalived)

前言 在分布式架构中,负载均衡和高可用是保障系统稳定性的两大核心能力。本文将深入讲解如何通过Nginx实现七层负载均衡,并结合Keepalived构建无单点故障的高可用架构。文末附完整配置模板! 一、Nginx负载均衡实现方案 1. 核心原理 Nginx通…...

SQLMesh调度系统深度解析:内置调度与Airflow集成实践

本文系统解析SQLMesh的两种核心调度方案:内置调度器与Apache Airflow集成。通过对比两者的适用场景、架构设计和操作流程,为企业构建可靠的数据分析流水线提供技术参考。重点内容包括: 内置调度器的轻量级部署与性能优化策略Airflow集成的端到…...

Excel 中 INDEX 和 VLOOKUP 的对比

INDEX 和 VLOOKUP 都是 Excel 中常用的查找函数,但它们的用途和灵活性有所不同。 1. 相同点 均可用于查找数据:都能根据某个条件返回目标值。 支持精确匹配:均可使用 0 或 FALSE 进行精确匹配。 2. 不同点 特性VLOOKUPINDEX MATCH查找方向…...

Multism TL494仿真异常

仿真模型如下:开关频率少了一半,而且带不动负载,有兄弟知道为什么吗 这里写自定义目录标题 欢迎使用Markdown编辑器新的改变功能快捷键合理的创建标题,有助于目录的生成如何改变文本的样式插入链接与图片如何插入一段漂亮的代码…...

基于 Trae 的超轻量级前端架构设计与性能优化实践

一、技术背景与选型动因 在单页应用(SPA)复杂度指数级增长的今天,传统框架在千级列表渲染场景下普遍存在首屏延迟(>1.5s)、内存占用过高(>200MB)等问题。基于对 Webpack Bundle Analyzer 的长期观察,我们发现核心问题集中在: • 类组件…...

算法练习(队列)

队列 单向队列 1. 定义一个队列 Queue<Integer> q new LinkedList<>(); Queue<Character> q new LinkedList<>();2. 入队列 q.offer(1); q.offer(2); // 从队尾入队列 q.add();3. 出队列 q.poll() // 从队头出队列&#xff0c;并将删除的元素…...

HarmonyOS NEXT开发进阶(十五):日志打印 hilog 与 console.log 的区别

文章目录 一、前言二、两者区别对比三、HiLog 详解四、拓展阅读 一、前言 在日常开发阶段&#xff0c;日志打印是调试程序非常常用的操作&#xff0c;在鸿蒙的官方文档中介绍了hilog这种方式&#xff0c;前端转过来的开发者发现console.log也可以进行日志打印&#xff0c;而且…...

【差分隐私相关概念】差分隐私中的稀疏向量技术

差分隐私中的稀疏向量技术&#xff08;Sparse Vector Technique, SVT&#xff09; 稀疏向量技术&#xff08;SVT&#xff09;是差分隐私中的一种高效机制&#xff0c;专用于处理稀疏高影响查询的场景。其核心思想是&#xff1a;当面对大量查询时&#xff0c;仅对其中“显著超过…...

快速幂算法还有用吗?——从内置函数到高性能计算的深度解析

博主在学习过程中遇到了一个疑问&#xff0c;既然C语言中有内置函数pow&#xff0c;那为什么还需要算法思想中的快速幂算法呢&#xff1f;下面将会讲解快速幂算法在特定场景下依然非常有用&#xff0c;具体原因如下&#xff1a; 目录 1. 精度与整数运算 2. 性能对比 3. 应用场…...

开源测试用例管理平台

不可错过的10个开源测试用例管理平台&#xff1a; PingCode、TestLink、Kiwi TCMS、Squash TM、FitNesse、Tuleap、Robot Framework、SpecFlow、TestMaster、Nitrate。 开源测试用例管理工具提供了一种透明、灵活的解决方案&#xff0c;使团队能够在不受限的情况下适应具体的测…...

vue 权限应用

目录 一、系统菜单栏权限 二、系统页面按钮权限 在企业开发中&#xff0c;不同的用户所扮演的角色不一样&#xff0c;角色拥有权限&#xff0c;所以用户拥有角色&#xff0c;就会有角色对应的权限。例如&#xff0c;张三是系统管理员角色&#xff0c;登录后就拥有整个系统的…...

鸿蒙HarmonyOS NEXT设备升级应用数据迁移流程

数据迁移是什么 什么是数据迁移&#xff0c;对用户来讲就是本地数据的迁移&#xff0c;终端设备从HarmonyOS 3.1 Release API 9及之前版本&#xff08;单框架&#xff09;迁移到HarmonyOS NEXT&#xff08;双框架&#xff09;后保证本地数据不丢失。例如&#xff0c;我在某APP…...

利用 PCI-Express 交换机实现面向未来的推理服务器

在数据中心系统的历史上&#xff0c;没有比被 Nvidia 选为其 AI 系统的组件供应商更高的赞誉了。 这就是为什么新兴的互连芯片制造商 Astera Labs 感到十分高兴&#xff0c;因为该公司正在 PCI-Express 交换机、PCI-Express 重定时器和 CXL 内存控制器方面与 Broadcom 和 Marv…...

Python调用手机摄像头检测火焰烟雾的三种方法

方法1&#xff1a;使用IP摄像头应用 OpenCV 1. 在手机上安装IP摄像头应用&#xff08;如IP Webcam for Android&#xff09; 2. 配置应用并启动服务器 3. 在Python中使用OpenCV连接 import cv2 import numpy as np # 手机IP摄像头URL&#xff08;替换为你的手机IP和端口…...

Python if else while for 学习笔记

一.if&#xff0c;else if语句用于根据条件执行代码块 else语句可与if语句结合&#xff0c;当if判断为假时执行else语句 x10 if x>5:print("x大于5") y3 if y>5:print("y大于5") else:print("y小于等于5")结果&#xff1a; 二.while循环…...

正则化是什么?

正则化&#xff08;Regularization&#xff09;是机器学习中用于防止模型过拟合&#xff08;Overfitting&#xff09;的一种技术&#xff0c;通过在模型训练过程中引入额外的约束或惩罚项&#xff0c;降低模型的复杂度&#xff0c;从而提高其泛化能力&#xff08;即在未见数据上…...

搜索-BFS

马上蓝桥杯了&#xff0c;最近刷了广搜&#xff0c;感觉挺有意思的&#xff0c;广搜题类型都差不多&#xff0c;模板也一样&#xff0c;大家写的时候可以直接套模板 这里给大家讲一个比较经典的广搜题-迷宫 题目问问能否走到 (n,m) 位置&#xff0c;假设最后一个点是我们的&…...

《边缘计算风云录:FPGA与MCU的算力之争》

点击下面图片带您领略全新的嵌入式学习路线 &#x1f525;爆款热榜 88万阅读 1.6万收藏 文章目录 **第一章&#xff1a;边城烽烟——数据洪流压境****第二章&#xff1a;寒铁剑匣——FPGA的千机变****第三章&#xff1a;枯木禅杖——MCU的至简道****第四章&#xff1a;双生契…...

R-GCN-Modeling Relational Data with GraphConvolutional Networks(论文笔记)

CCF等级&#xff1a;B 发布时间&#xff1a;2018年6月 25年3月31日交 目录 一、简介 二、原理 1.整体 2.信息交换与更新 2.1基分解 2.2块对角矩阵 3.实体分类或链接预测 3.1实体分类 3.2链接预测 三、结论和未来工作 一、简介 RGCN通过允许不同关系类型之间的信息…...

蓝桥杯第十六届模拟赛——基础细节考频分析

文章目录 前言一、STL函数二、日期问题三、质数与约数四、基本常识总结 前言 一、STL函数 #include< cmath > 详解floor函数、ceil函数和round函数 1.floor() 功能&#xff1a;把一个小数向下取整如果数是2.2 &#xff0c;那向下取整的结果就为2.000000如果数是-2.2 &…...

【C++初阶】----模板初阶

1.泛型函数 泛型编程&#xff1a;编写与类型无关的通用代码&#xff0c;是代码复用的一种手段。模板是泛型编程的基础。 2.函数模板 2.1函数模板的概念 函数模板代表了一个函数家族&#xff0c;该函数模板与类型无关&#xff0c;在使用时被参数化&#xff0c;根据实参类型…...

PyCharm操作基础指南

一、安装与配置 1. 版本选择 专业版&#xff1a;支持 Web 开发&#xff08;Django/Flask&#xff09;、数据库工具、科学计算等&#xff08;需付费&#xff09;。 社区版&#xff1a;免费&#xff0c;适合纯 Python 开发。 2. 安装步骤 访问 JetBrains 官网 下载对应版本。…...

Pycharm(七):几个简单案例

一.剪刀石头布 需求&#xff1a;和电脑玩剪刀石头布游戏 考察点&#xff1a;1.随机数&#xff1b;2.判断语句 import random # numrandom.randint(1,3) # print(num) # print(**30) #1.录入玩家手势 playerint(input(请输入手势&#xff1a;&#xff08;1.剪刀 2.石头 3&…...

Android并发编程:线程池与协程的核心区别与最佳实践指南

1. 基本概念对比 特性 线程池 (ThreadPool) 协程 (Coroutine) 本质 Java线程管理机制 Kotlin轻量级并发框架 最小执行单元 线程(Thread) 协程(Coroutine) 创建开销 较高(需分配系统线程资源) 极低(用户态调度) 并发模型 基于线程的抢占式调度 基于协程的协作式调度 2. 核心差异…...

MySQL内存使用率高问题排查与解决方案:

目录标题 **一、问题现象****二、核心排查步骤****1. 参数检查****2. 内存使用分析****3. 存储过程/函数/视图检查****4. 操作系统级检查** **三、解决方案****1. 调整MySQL配置****2. 关闭透明大页&#xff08;THP&#xff09;****3. 优化查询与存储过程****4. 硬件与环境优化…...

gnvm切换node版本号

1. gnvm下载官网 GNVM - Node.js version manager on Windows by Go 2. 安装 2.1 不存在 Node.js 环境 下载并解压缩 gnvm.exe 保存到任意文件夹&#xff0c;并将此文件夹加入到环境变量 Path。 2.2 存在 Node.js 环境 下载并解压缩 gnvm.exe 保存到 Node.js 所在的文件夹。 2.…...

PyTorch 深度学习实战(29):目标检测与 YOLOv12 实战

在上一篇文章中&#xff0c;我们探讨了对比学习与自监督表示学习。本文将深入计算机视觉的核心任务之一——目标检测&#xff0c;重点介绍最新的 YOLOv12 (You Only Look Once v12) 算法。我们将使用 PyTorch 实现 YOLOv12 模型&#xff0c;并在 COCO 数据集上进行训练和评估。…...

Python爬虫:开启数据抓取的奇幻之旅(一)

目录 一、爬虫初印象&#xff1a;揭开神秘面纱​ 二、工欲善其事&#xff1a;前期准备​ &#xff08;一&#xff09;Python 环境搭建​ 1.下载 Python 安装包&#xff1a;​ 2.运行安装程序&#xff1a;​ 3.配置环境变量&#xff08;若自动添加失败&#xff09;&#x…...

python下载m3u8格式视频

一、安装 m3u8库 pip install requests pip install requests m3u8 二、编码实现 import os import re import requests import subprocess# 下载ts文件 def down_ts_file(base_url, m3u8_url, download_dir):# 从m3u8文件中获取所有ts的分片名称信息response requests.get…...

【区块链安全 | 第五篇】DeFi概念详解

文章目录 DeFi1. DeFi 生态概览2. 去中心化交易所&#xff08;DEX&#xff09;2.1 AMM&#xff08;自动做市商&#xff09;模型2.2 订单簿模式&#xff08;现货交易&#xff09; 3. 借贷协议3.1 Aave3.2 使用闪电贷&#xff08;Flash Loan&#xff09; 4. 稳定币&#xff08;St…...