(十七) Nginx解析:架构设计、负载均衡实战与常见面试问题

什么是Nginx?

Nginx 是一款高性能的 HTTP 服务器和反向代理服务器,同时支持 IMAP/POP3/SMTP 协议。其设计以高并发、低资源消耗为核心优势,广泛应用于负载均衡、静态资源服务和反向代理等场景。

一、Nginx 的核心优势

  1. 高并发处理能力采用异步非阻塞的 I/O 多路复用模型(如 epoll/kqueue),单机可支持 5 万+ 并发连接。相比传统多线程模型(如 Apache),资源消耗更低,内存占用仅为 Apache 的 1/5-1/10。
  2. 反向代理与负载均衡支持轮询、权重分配、IP哈希等策略,实现流量分发到多台后端服务器,提升系统容错性和处理效率。内置健康检查功能,自动剔除故障节点,保障服务可用性。
  3. 低资源消耗与高稳定性基于事件驱动模型,CPU 亲和性设计减少上下文切换开销。支持热部署,可在不中断服务的情况下更新配置或版本。
  4. 灵活的扩展性模块化架构支持第三方插件扩展(如缓存、安全防护等)。配置文件简洁,支持 Rewrite 规则和正则表达式匹配。

二、主要功能与应用场景

  1. Web 服务器静态资源高效处理:直接托管 HTML、图片等文件,响应速度远超传统服务器。动静分离:将动态请求(如 PHP、Node.js )与静态资源(如 CSS、JS)分开处理,降低后端压力。
  2. 反向代理与安全防护隐藏真实服务器 IP,抵御 DDoS 攻击,支持 SSL/TLS 加密。通过访问控制(IP 白名单、HTTP 认证)提升安全性。
  3. 缓存与性能优化支持 GZIP 压缩和浏览器缓存,减少带宽消耗。反向代理缓存动态内容,降低后端服务器负载。
  4. 邮件代理与多协议支持可作为 IMAP/POP3/SMTP 代理服务器,处理邮件收发请求。

三、典型应用场景

  • 大型网站架构:如新浪、腾讯等,用于负载均衡和静态资源加速。
  • 微服务网关:作为 API 网关统一管理请求路由和限流。
  • 内容分发网络(CDN):结合缓存机制加速静态资源访问。

四、与其他服务器的对比

特性

Nginx

Apache

并发模型

异步非阻塞(epoll)

多线程/多进程

内存消耗

低(约 2.5MB/万连接)

高(约 20MB/进程)

热部署

支持

不支持

五、核心架构与事件驱动模型

1. 多进程架构设计

• Master - Worker机制
主进程(Master)承担管理配置、信号分发以及监控工作进程(Worker)的职责,支持热部署(借助nginx -s reload可在无需停机的情况下进行更新)。工作进程(Worker)基于异步非阻塞模型构建,单线程能够处理数以万计的并发连接,通过共享内存达成高效通信。

2. 事件驱动模型

• Epoll/Kqueue高效处理
采用Reactor模式,仅聚焦于活跃连接(相较于select/poll,减少了O(n)的遍历开销),可实现单个Worker处理超过10万的并发连接。每个Worker独立运行事件循环,避免了线程切换的开销。

3. 内存管理优化

• 静态资源处理的内存消耗低至2.5MB/万连接,借助内存池机制减少内存碎片。

六、负载均衡深度配置

1. 基础配置模板

http {upstream backend {# 加权轮询(默认策略)server 192.168.1.101:8080 weight=5; server 192.168.1.102:8080 weight=3; server 192.168.1.103:8080 backup;  # 备用节点 # 策略选择 ip_hash;       # 会话保持(解决Session问题)# least_conn;  # 最小连接数策略 }server {location / {proxy_pass http://backend; proxy_set_header Host $host; }}
}

2. 高级策略解析

策略类型

适用场景

特点

IP哈希

需会话保持的业务(如购物车)

相同IP始终路由到固定节点,可能引发负载不均

加权最少连接

服务器性能差异大的集群

动态选择当前连接数最少的节点,需配合健康检查使用

响应时间优先

对延迟敏感的应用

需安装第三方模块(如nginx-upstream-fair),根据响应时间动态分配请求

七、常见面试题

Nginx 是一款轻量级的高性能 Web 服务器、反向代理服务器以及电子邮件(IMAP/POP3)代理服务器,由俄罗斯的软件工程师 Igor Sysoev 开发。以下是关于 Nginx 的详细介绍及其常见应用场景:

Nginx 的特点

  • 高性能和稳定性:Nginx 采用了事件驱动的异步非阻塞模型,能够在高并发情况下保持低资源消耗和高响应速度,稳定性强,可长时间稳定运行。
  • 低内存占用:在处理大量并发连接时,Nginx 对内存的占用相对较少,能够高效利用系统资源。
  • 丰富的模块功能:支持众多的模块,如 HTTP 模块、SSL 模块、反向代理模块等,通过这些模块可以方便地实现各种功能扩展。
  • 热部署:可以在不停止服务的情况下进行配置文件的更新和模块的升级,保证服务的连续性。

应用场景

Nginx 是什么?

Nginx 是一款轻量级的高性能 Web 服务器、反向代理服务器以及电子邮件(IMAP/POP3)代理服务器,由俄罗斯的软件工程师 Igor Sysoev 开发.

它有哪些应用场景?

  • Web 服务器:可作为独立的 Web 服务器,直接处理静态资源请求,如 HTML、CSS、JavaScript、图片等文件。它能够高效地将这些静态文件发送给客户端,减轻后端应用服务器的压力。
  • 反向代理服务器:Nginx 常被用于反向代理场景,接收互联网用户的请求,并将请求转发到后端的真实服务器上。同时,它还可以对后端服务器的响应进行缓存、过滤等处理,提高系统的性能和安全性。例如,当有大量用户访问一个网站时,Nginx 可以根据预设的规则,将请求分发到不同的后端服务器上,实现负载均衡,提升整体系统的处理能力。
  • 负载均衡器:Nginx 可以实现对多个后端服务器的负载均衡,通过轮询、IP 哈希、加权轮询等多种算法,将客户端请求均匀地分配到不同的服务器上,使各服务器的负载相对均衡,避免单点故障,提高系统的可靠性和可用性。
  • SSL/TLS 终端代理:Nginx 可以对 SSL/TLS 加密的流量进行处理,实现 SSL/TLS 的卸载。即 Nginx 在前端接收加密的 HTTPS 请求,进行解密后再将明文请求转发给后端服务器,这样可以减轻后端服务器的加密计算压力,提高整体系统的性能。
  • HTTP 缓存服务器:Nginx 可以对经常访问的静态资源和部分动态资源进行缓存,当客户端再次请求相同资源时,Nginx 可以直接从缓存中返回数据,而无需向后端服务器发送请求,大大提高了响应速度,降低了后端服务器的负载,节省了带宽资源。
  • 邮件代理服务器:Nginx 还可以作为电子邮件(IMAP/POP3)代理服务器,为邮件系统提供代理和缓存功能,提高邮件系统的性能和可靠性。

如何配置 Nginx 实现静态资源访问?

设置nginx.config 文件, 配置具体的访问路径

Nginx 的常用命令有哪些?

  • 启动 : nginx
  • 停止 : nginx -s stop
  • 重启: nginx -s restart
  • 先停止再启动 : nginx -s stop && sudo nginx
  • 重载配置文件: sudo nginx -s reload
  • 检查配置文件语法: nginx -t
  • 查看 Nginx 版本信息: nginx -v

如何在 Nginx 中获取当前时间?

$time_local或$time_iso8601来获取当前时间

Nginx 命令中 -s 参数的作用是什么?具体有哪些用法?

向主进程Matser发送信号来控制Worker进程, 如 nginx -s stop 等

如何禁止某个 IP 的访问?

在设置nginx.config 文件 中加入 如 ''deny 127.0.0.2"等,配置完后重新加载nginx

如何实现请求的重定向?

在设置nginx.config 文件 中加入 "如old-path-->new-path"

location /old-path {rewrite ^/old-path$ /new-path permanent;
}

什么是正向代理和反向代理?

  • 正向代理:为客户端服务,客户端主动使用,向代理服务器发送请求,代理再转发到目标服务器,可突破访问限制等,隐藏真实客户端。
  • 反向代理:为服务器服务,客户端无感知,请求直接到反向代理服务器,由其转发到内部真实服务器,常用于负载均衡等,隐藏真实服务器。

如何使用 Nginx 做反向代理?

  1. 安装 Nginx:以 Ubuntu 系统为例,通过 sudo apt update 和 sudo apt install nginx 命令完成安装。
  2. 配置反向代理编辑配置文件,常见路径为 /etc/nginx/sites - available/default 或 /etc/nginx/conf.d/default.conf。
  3. 检查配置语法:使用 sudo nginx -t 命令检查配置文件语法是否正确。
  4. 重新加载配置:执行 sudo systemctl reload nginx 使新配置生效。
  5. 验证反向代理:通过浏览器或其他工具访问配置的域名,验证请求是否被正确转发到后端服务器。

如何用 Nginx 做限流,有几种限流算法,分别如何实现?

限流算法介绍

  • 漏桶算法:将请求视为水,以固定速率处理,超量请求在桶中等待,桶满则丢弃新请求,用于严格控制请求速率的场景。
  • 令牌桶算法:系统按固定速率向桶中放令牌,请求需获取令牌才能处理,允许一定突发请求,适用于对突发流量有容忍度的场景。

实现方式

基于漏桶算法(limit_req模块)

  1. 配置限流区域:在 http 块定义,如 limit_req_zone $binary_remote_addr zone=mylimit:10m rate=10r/s,依据客户端 IP 限流,每秒允许 10 个请求。
  2. 应用限流规则:在 server 或 location 块使用,如 limit_req zone=mylimit burst=20 nodelay,指定限流区域、突发请求数及不排队处理。

模拟令牌桶算法(limit_req模块结合burst参数)

通过设置 burst 参数,允许短时间内有额外 “令牌” 处理突发请求,突破 rate 限制但在 burst 范围内的请求可立即处理。

基于连接数限流(limit_conn模块)

  1. 配置连接限制区域:在 http 块定义,如 limit_conn_zone $binary_remote_addr zone=perip:10m,按客户端 IP 限制连接数。
  2. 应用连接限制规则:在 server 或 location 块使用,如 limit_conn perip 10 限制每个客户端 IP 并发连接数为 10 个。

为什么 Nginx 的性能那么高?

源于其多进程单线程与模块化的架构设计、异步非阻塞I/O的事件处理机制、高效的内存池与低内存占用管理、HTTP 及反向代理缓存机制以及对 HTTP 和 SSL/TLS 协议的优化处理。

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

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

相关文章

PCIE接口

PCIE接口 PIC接口介绍PIC总线结构PCI总线特点PCI总线的主要性能PIC的历程 PCIE接口介绍PCIe接口总线位宽PCIE速率GT/s和Gbps区别PCIE带宽计算 PCIE架构PCIe体系结构端到端的差分数据传递PCIe总线的层次结构事务层数据链路层物理层PCIe层级结构及功能框图 PCIe链路初始化PCIe链路…

边缘计算盒子:解决交通拥堵的智能方案

在当今的智能交通系统中,边缘计算盒子(Edge Computing Box)正逐渐成为不可或缺的核心组件。这种设备通过将计算能力下沉到网络边缘,极大地提升了数据处理的速度和效率,特别适用于实时性要求极高的交通监控场景。本文将…

INFINI Labs 产品更新 | Easysearch 增加异步搜索等新特性

INFINI Labs 产品更新发布!此次更新,Easysearch 增加了新的功能和数据类型,包括 wildcard 数据类型、Point in time 搜索 API、异步搜索 API、数值和日期字段的 doc-values 搜索支持,Console 新增了日志查询功能。 INFINI Easyse…

Kotlin从入门到精通:开启高效编程之旅

目录 一、为什么选择 Kotlin 二、Kotlin 基础语法入门​ 2.1 Hello, Kotlin​ 2.2 变量与数据类型​ 2.2.1 可变与不可变变量​ 2.2.2 基本数据类型​ 2.2.3 数组​ 三、Kotlin 流程控制与函数​ 3.1 流程控制语句​ 3.1.1 if 表达式​ 3.1.2 when 表达式​ 3.2 函…

大模型量化技术实践指南:GPTQ、AWQ、BitsandBytes 和 Unsloth

在大模型(LLM)的时代,我们需要了解量化技术,以便在本地电脑上运行这些模型,因为它们的规模非常庞大。然而,实现量化的方法有很多,这让像我这样的初学者很容易感到困惑。本文介绍了我们必须掌握的…

C51 Proteus仿真实验16:4X4矩阵键盘控制条形LED显示

说明 按下的按键值越大点亮的LED越多 Proteus仿真 注意: K1、K5、K9、K13左边引脚连接的是P1.0 K2、K6、K10、K14左边引脚连接的是P1.1 K3、K7、K11、K15左边引脚连接的是P1.2 K4、K8、K12、K16左边引脚连接的是P1.3 K1、K2、K3、K4右边引脚连接的是P1.4 K5、K6、…

Hive的架构

1. 概念 Hive 是建立在 Hadoop 上的数据仓库工具,旨在简化大规模数据集的查询与管理。它通过类 SQL 语言(HiveQL)将结构化数据映射为 Hadoop 的 MapReduce,适合离线批处理,尤其适用于数据仓库场景。 2. 数据模型 表&a…

P8686 [蓝桥杯 2019 省 A] 修改数组--并查集

P8686 [蓝桥杯 2019 省 A] 修改数组--并查集 题目 解析代码 题目 解析 首先先让所有的f(i)i,即每个人最开始的祖先都是自己,然后就每一次都让轮到那个数的父亲1,第二次出现的时候就直接用父亲替换掉 并查集适用场景 …

GitHub上传项目

总结(有基础的话直接执行这几步,就不需要再往下看了): git init 修改git的config文件:添加:[user]:name你的github用户名 email你注册github的用户名 git branch -m master main git remote add origin 你的URL gi…

关于Windows输入法切换的一些总结

语言和键盘的关系(第一层是语言 语言下一层是键盘) 如下图:语言就是 中文 英文 阿拉伯文之类的 键盘就是 语言中文下的:XX输入法 语言的切换 和 键盘(输入法)的切换 (用windos空格 可以切换…

C# Unity 唐老狮 No.7 模拟面试题

本文章不作任何商业用途 仅作学习与交流 安利唐老狮与其他老师合作的网站,内有大量免费资源和优质付费资源,我入门就是看唐老师的课程 打好坚实的基础非常非常重要: 全部 - 游习堂 - 唐老狮创立的游戏开发在线学习平台 - Powered By EduSoho 如果你发现了文章内特殊的字体格式,…

搜广推校招面经三十九

小红书﹣图搜 一、两个整数的汉明距离 两个整数之间的汉明距离是指这两个数字对应二进制位相同位置不同的个数。换句话说,它就是将一个整数变成另一个整数所需要改变的二进制位的数量。例如,如果两个整数在它们的二进制表示中有三个位置上的…

conda list <package> 指令输出的build和channel含义

Build:表示当前安装包的 构建版本,即该包的编译、构建、发布的具体版本。通常包含一些额外的标识,帮助你区分同一包的不同版本。 Channel: 表示该包的 来源渠道,即该包是从哪个 Anaconda 仓库(频道&#…

Windows下配置Flutter移动开发环境以及AndroidStudio安装和模拟机配置

截止 2025/3/9 ,版本更新到了 3.29.1 ,但是为了防止出现一些奇怪的bug,我安装的还是老一点的,3.19,其他版本的安装同理。AndroidStudio用的是 2024/3/1 版本。 — 1 环境变量(Windows) PUB_H…

Linux系统编程--线程同步

目录 一、前言 二、线程饥饿 三、线程同步 四、条件变量 1、cond 2、条件变量的使用 五、条件变量与互斥锁 一、前言 上篇文章我们讲解了线程互斥的概念,为了防止多个线程同时访问一份临界资源而出问题,我们引入了线程互斥,线程互斥其实…

学习小程序开发--Day1

项目学习开篇 项目架构 项目进程 创建uni-app项目 通过HBuilderX创建 小结 page.json 和 tabBar 目录文件 pages.json的配置

在word下写公式

需求 word的可视化编辑公式是好的,但是很丑(见下图) 我希望公式是这样的(见下图) 解决方案 1.先转换为“线性”(即Latex格式) 2.得到下面这个玩意,把\mathrm去掉(功能是…

uniapp,自绘仪表盘组件(基础篇)

文章目录 一、为什么需要自绘仪表盘?二、准备知识三、实现基础仪表盘1. 组件模板结构2. 核心绘制逻辑3. 样式优化 四、使用示例五、核心实现原理六、扩展方向七、常见问题 一、为什么需要自绘仪表盘? 在物联网、数据监控等场景中,仪表盘是常…

导入 Excel 规则批量修改或删除 Excel 表格内容

我们前面介绍过按照规则批量修改 Excel 文档内容的操作,可以对大量的 Excel 文档按照一定的规则进行统一的修改,可以很好的解决我们批量修改 Excel 文档内容的需求。但是某些场景下,我们批量修改 Excel 文档内容的场景比较复杂,比…

Python贝壳网二手小区数据爬取(2025年3月更)

文章目录 一、代码整体架构解析二、各部分代码详解1. main()主函数解析2. 会话初始化(伪装浏览器身份)3. 动态参数生成(反爬虫核心机制)4. 列表页抓取(获取小区列表)5. 列表页解析(提取小区信息…