Nginx技术方案【学习记录】

文章目录

  • 1. 需求分析
    • 1.1 应用场景
    • 1.2 实现目标
  • 2. Nginx反向代理与实现均衡负载
    • 2.1 部署架构
    • 2.2 架构描述
      • 2.2.1 Nginx代理服务器
      • 2.2.2 API服务器与API服务器(Backup)
      • 2.2.3 `nginx.conf`配置文件
      • 2.2.4 测试方法
  • 3. 高速会话缓存技术
    • 3.1 问题背景
    • 3.2 使用 Redis 存储 Session
      • 3.2.1 优势
      • 3.2.2 部署架构图
      • 3.2.3 后端配置

1. 需求分析

1.1 应用场景

  1. 经典的接口服务(API)访问场景:需要在多台后端服务器之间实现负载均衡,同时通过 Nginx 实现反向代理来对外统一出口
  2. 两台进行主负载均衡, 一台作为备用服务器(只有主服务器都不可用时才启用)

1.2 实现目标

  1. 多台 API 服务器之间实现请求均衡分发,提高服务并发能力
  2. 使用 Nginx 作为统一访问入口,隐藏后端结构
  3. 保证接口请求的响应速度和可靠性

2. Nginx反向代理与实现均衡负载

2.1 部署架构

image-20250425160444911

2.2 架构描述

2.2.1 Nginx代理服务器

需要有一个独立的前置 Nginx 服务器,用于接收所有客户端请求并进行反向代理和负载均衡。这个服务器不参与接口服务本身,而是作为网关服务器存在。

(单独一台机器或轻量容器,部署在公网可访问或局域网的前端位置)

2.2.2 API服务器与API服务器(Backup)

部署在内网的三台后端服务器,监听特定端口。其中Backup作为后备服务器,在请求访问主API服务器时启动。

2.2.3 nginx.conf配置文件

Nginx配置示例:


http {upstream api_backend {# 主服务器(轮询)server 192.168.1.101:5000 max_fails=3 fail_timeout=30s;server 192.168.1.102:5000 max_fails=3 fail_timeout=30s;# 后备服务器,仅在主服务器全部不可用时启用server 192.168.1.103:5000 backup;}server {listen 80;  # 对外暴露的portserver_name api.example.com;  # 对外暴露的hostlocation / {proxy_pass http://api_backend;# 常规头设置proxy_set_header Host $host;proxy_set_header X-Real-IP $remote_addr;proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;# 连接优化proxy_connect_timeout 5;proxy_send_timeout 30;proxy_read_timeout 30;}}
}

Nginx配置项说明:


配置项说明
upstream api_backend上游服务器池
max_fails最大失败次数
fail_timeout最大失败等待时间
proxy_connect_timeout连接后端服务器的超时时间(TCP 三次握手时间限制)
proxy_send_timeoutNginx 向后端服务器发送请求的超时时间
proxy_read_timeout等待后端服务器响应的最大时间

主服务器轮询机制:


  • 默认轮询(Round Robin)

    每个请求依次分发给后端服务器,不考虑服务器性能或连接数。

    upstream api_backend {server 192.168.1.101:5000;server 192.168.1.102:5000;
    }
    
  • 权重轮询(Weighted Round Robin)

    根据每台服务器的性能分配不同权重,权重越高,请求越多。

    upstream api_backend {server 192.168.1.101:5000 weight=3;server 192.168.1.102:5000 weight=1;
    }
    
  • 最少连接数(Least Connections)

    将请求分发给当前连接数最少的服务器。

    upstream api_backend {least_conn;server 192.168.1.101:5000;server 192.168.1.102:5000;
    }
    
  • IP 哈希(IP Hash)

    根据客户端 IP 分发请求,同一 IP 总是转发给同一台后端服务器,适合需要会话保持的情况。

    upstream api_backend {ip_hash;server 192.168.1.101:5000;server 192.168.1.102:5000;
    }
    

    注:ip_hash 不支持 backup 参数

算法特点适用场景
Round Robin简单依次转发默认,性能相近的服务器
Weight按性能分配负载部分服务器性能较强
Least Conn优先连接少的服务器请求耗时长/负载不均
IP Hash同 IP 请求同一服务器需要 Session 保持

后备服务器生效机制(Backup)


Nginx 会自动探测主服务器失败(例如连接超时、502、503等),如果全部主节点失败,则自动切换到 backup 节点处理请求。

2.2.4 测试方法

  1. 正常访问时,轮询 Server1 和 Server2
  2. 停止 Server1 和 Server2,再访问接口,请求会自动落到 Server3
  3. 恢复主节点后,访问会自动回归主服务器

3. 高速会话缓存技术

3.1 问题背景

在使用 Nginx 做负载均衡时,请求会被分发到不同的后端服务器,而如果会话(Session)信息保存在单台服务器上,会导致以下问题:

  • 登录状态丢失
  • 用户需要重复登录
  • 无法维持用户上下文信息

3.2 使用 Redis 存储 Session

3.2.1 优势

  • 快速、共享、可横向扩展
  • 多个后端节点可以访问同一份 Session 数据

3.2.2 部署架构图

image-20250425171927386

3.2.3 后端配置

在 Flask / Django / Spring Boot 等应用中配置:

  • 将用户 Session 保存在 Redis 中(而非本地内存)
  • 各服务器通过 Redis 获取 Session 数据

Flask示例:

# Flask 示例(使用 Flask-Session)
from flask import Flask, session
from flask_session import Sessionapp = Flask(__name__)
app.config['SESSION_TYPE'] = 'redis'
app.config['SESSION_REDIS'] = redis.Redis(host='localhost', port=6379)
Session(app)

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

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

相关文章

Ubuntu22.04怎么退出Emergency Mode(紧急模式)

1.使用nano /etc/fstab命令进入fstab文件下; 2.将挂载项首行加#注释掉,修改完之后使用ctrlX退出; 3.重启即可退出紧急模式!

Unity 红点系统

首先明确一个,即红点系统的数据结构是一颗树,并且红点的数据结构的初始化需要放在游戏的初始化中,之后再是对应的红点UI侧的注册,对应的红点UI在销毁时需要注销对红点UI的显示回调注册,但是不销毁数据侧的红点注册 - …

极新携手火山引擎,共探AI时代生态共建的破局点与增长引擎

在生成式AI与行业大模型的双重驱动下,人工智能正以前所未有的速度重构互联网产业生态。从内容创作、用户交互到商业决策,AI技术渗透至产品研发、运营的全链条,推动效率跃升与创新模式变革。然而,面对AI技术迭代的爆发期&#xff0…

【Redis】SDS结构

目录 1、背景2、SDS底层实现 1、背景 redis作为高性能的内存数据库,对字符串操作(如键、值的存储)有极高的要求。c语言原生字符串(以\0结尾的字符串数据)有一些缺点:长度计算需要遍历(O(n)时间…

STM32硬件I2C驱动OLED屏幕

本文基于STM32硬件I2C驱动SSD1306 OLED屏幕,提供完整的代码实现及关键注意事项,适用于128x32或128x64分辨率屏幕。代码通过模块化设计,支持显示字符、数字、汉字及位图,并优化了显存刷新机制。 零、完整代码 完整代码: 1&#x…

鸿蒙 PC 发布之后,想在技术上聊聊它的未来可能

最近鸿蒙 PC 刚发布完,但是发布会没公布太多技术细节,基本上一些细节都是通过自媒体渠道获取,首先可以确定的是,鸿蒙 PC 本身肯定是无法「直接」运行 win 原本的应用,但是可以支持手机上「原生鸿蒙」的应用&#xff0c…

【JAVA】抽象类与接口:设计模式中的应用对比(16)

核心知识点详细解释 Java抽象类和接口的定义、特点和使用场景 抽象类 抽象类是使用 abstract 关键字修饰的类。它不能被实例化,主要用于作为其他类的基类,提供一些通用的属性和方法。抽象类可以包含抽象方法和具体方法。抽象方法是使用 abstract 关键…

HTML 颜色全解析:从命名规则到 RGBA/HSL 值,附透明度设置与场景应用指南

一、HTML 颜色系统详解 HTML 中的颜色可以通过多种方式定义,包括颜色名称、RGB 值、十六进制值、HSL 值等,同时支持透明度调整。以下是详细分类及应用场景: 1. 颜色名称(预定义关键字) HTML 预定义了 140 个标准颜色名…

LVS负载均衡群集和keepalive

目录 一. 集群概述 1.1 集群的定义 1.2 集群的分类 1. 高可用集群 HA 2. 高性能运输群集 HPC 3.负载均衡群集 LB 4. 分布式存储集群 二. LVS概述 2.1 LVS的定义 2.2 LVS的工作原理 2.3 LVS 的三种工作模式 2.4 LVS 三种工作模式的对比 2.5 LVS 调度算法 1. 静态…

ZTE 7551N 中兴小鲜60 远航60 努比亚小牛 解锁BL 刷机包 刷root 展讯 T760 bl

ZTE 7551N 中兴小鲜60 远航60 努比亚小牛 解锁BL 刷机包 刷root 3款机型是一个型号,包通用, ro.product.system.modelZTE 7551N ro.product.system.nameCN_P720S15 #################################### # from generate-common-build-props # Th…

单片机-STM32部分:12、I2C

飞书文档https://x509p6c8to.feishu.cn/wiki/MsB7wLebki07eUkAZ1ec12W3nsh 一、简介 IIC协议,又称I2C协议,是由PHILP公司在80年代开发的两线式串行总线,用于连接微控制器及其外围设备,IIC属于半双工同步通信方式。 IIC是一种同步…

Virtualized Table 虚拟化表格 el-table-v2 表头分组 多级表头的简单示例

注意添加这个属性,会影响到有多少个层级的表头: :header-height“[50, 40]”,即后面的columnIndex 如果有fix的列CustomizedHeader会被调用多次,如果有多个层级的表头,也会被调用多次, 实际被调用次数是(fix数 1 * 表头层级数量) 以下代码均删除了JSX TS版本代码 <templ…

防御保护-----第十二章:VPN概述

文章目录 第二部分&#xff0c;数据安全第十二章&#xff1a;VPN概述VPN概述VPN分类VPN关键技术隧道技术身份认证技术加解密技术数据认证技术 数据的安全传输密码学发展史 对称加密算法 --- 传统密码算法密钥解释流加密分组加密 --- 块加密算法填充算法PKCS7算法分组模式 公钥密…

前端项目打包部署流程j

1.打包前端项目(运行build这个文件) 2.打包完成后&#xff0c;控制台如下所示:(没有报错即代表成功) 3.左侧出现dist文件夹 4.准备好我们下载的nginx(可以到官网下载一个),然后在一个没有中文路径下的文件夹里面解压。 5.在继承终端内打开我们的项目&#xff0c;找到前面打包好…

Go语言标识符

文章目录 标识符的组成规则Go语言关键字预定义标识符标识符命名惯例 特殊标识符标识符访问权限控制 在Go语言中&#xff0c;标识符(Identifier)是用来命名变量、函数、类型、常量等程序实体的名称。 标识符的组成规则 1、必须以字母或下划线(_)开头&#xff1a; 字母包括Unico…

CST软件对OPERACST软件联合仿真汽车无线充电站对人体的影响

上海又收紧了新能源车的免费上牌政策。所以年前一些伙伴和我探讨过买新能源汽车的问题&#xff0c;小伙伴们基本纠结的点是买插电还是纯电&#xff1f;我个人是很抗拒新能源车的&#xff0c;也开过坐过。个人有几个观点&#xff1a; 溢价过高&#xff0c;不保值。实际并不环保…

吴恩达机器学习笔记:多变量梯度下降

1.多维特征 之前我们探讨了单变量/特征的回归模型&#xff0c;现在我们对房价模型增加更多的特征&#xff0c;例如房间数楼层等&#xff0c;构成一个含有多个变量的模型&#xff0c;模型中的特征为 &#xff08; x 1 &#xff0c; x 2 &#xff0c; x 3... x n &#xff09; &…

【Linux Nano Vim快捷键大全】

Nano 快捷键大全 常用高频操作 功能描述快捷键组合替代按键/备注使用频率显示帮助CtrlGF1高保存文件CtrlOF3高退出编辑器CtrlXF2高剪切当前行CtrlKF9高粘贴内容CtrlUF10高搜索文本CtrlWF6高替换文本Ctrl\AltR高撤销操作AltU无中重做操作AltE无中跳转到行号Ctrl_AltG中插入文件…

uniapp vue 沉浸式窗体如何获取并排除外部手机浏览器底部菜单栏工具栏高度

这个问题可以简称为&#xff1a;uniapp vue 获取可视窗口高度 第一种方案&#xff0c;只改变css样式 /* 不考虑浏览器UI的最小视口高度 */ .element {height: 100svh; /* small viewport height */ }/* 考虑浏览器UI变化的动态视口高度 */ .element {height: 100dvh; /* dyna…

React Native告别图标体积大手动更换慢的噩梦:让图标更新像修改文字一样简单

写在前面:凌晨三点的图标战争 “所有图标都要换成圆角风格,明天上线!”——产品经理这条消息弹出时,我的保温杯差点从手中滑落。扫了一眼项目中的347个图标文件,我知道今晚又是个不眠夜。但就在绝望之际,同事发来一个GIF:他只是在终端输入了iconfont-rn --update,所有…