Nginx 运维开发高频面试题详解
一、基础核心问题
原文链接:https://blog.csdn.net/weixin_51146329/article/details/142963853
1、什么是Nginx?
Nginx 是一个高性能的 HTTP 和反向代理服务器,它以轻量级和高并发处理能力而闻名。Nginx 的反向代理功能允许它作为前端服务器,接收客户端的请求并将它们转发到后端服务器,这样可以隐藏后端服务器的细节,提高安全性Nginx 也能够作为负载均衡器,将流量分配到多个后端服务器,这样可以提高网站的可用性和扩展性。Nginx 还支持静态文件服务,由于其高效的文件处理能力,它经常被用来作为静态资源的服务器,如图片、CSS 和 JavaScript 文件等
2. Nginx的特点和优势是什么?
Nginx 是一个高性能的 HTTP 和反向代理服务器,具有以下特点和优势:
-
高并发处理:Nginx 使用异步非阻塞 I/O 模型(如
epoll
在 Linux 系统中),这使得它可以高效地处理大量并发连接。每个 Worker 进程可以处理数千个并发连接而不消耗过多资源 -
低内存消耗:由于其轻量级的设计,Nginx 占用的系统资源相对较少,即使在处理数万并发连接时也能保持较低的内存占用 ty-reference。
-
反向代理与负载均衡:Nginx 提供了强大的反向代理功能,并且支持多种负载均衡算法,比如轮询、加权轮询、IP Hash 等,能够有效地分散流量并提高服务可用性
-
热部署:Nginx 支持平滑重启(
nginx -s reload
),可以在不中断现有服务的情况下加载新的配置文件或升级到新版本 -
模块化设计:Nginx 的核心功能是通过一系列独立的模块实现的,这些模块可以根据需要进行编译加载,从而提供了高度的灵活性
3. Nginx的Master-Worker进程模型是如何工作的?
Nginx 采用了一种称为 Master-Worker 的架构来管理请求处理流程:
-
Master 进程:作为主控进程,它负责读取和验证配置文件、绑定端口以及启动和监控 Worker 进程。此外,Master 还能响应来自管理员的操作指令,例如重新加载配置或者优雅地关闭服务
-
Worker 进程:由 Master 创建的多个 Worker 进程实际负责处理客户端请求。每个 Worker 都是一个单线程进程,利用事件驱动机制处理网络I/O操作。通常情况下,Worker 的数量设置为 CPU 核心数以最大化硬件利用率
4、Nginx怎么处理请求的?
1、接收请求:当客户端发送一个 HTTP 请求到 Nginx 时,Nginx 的工作进程或线程会接收这个请求。
2、匹配 Server 和 Location:Nginx 会根据请求的域名和 URI 匹配相应的 server 块和 location 块。这是通过 listen 和 server_name 指令匹配 server 模块,再匹配 server 模块里的 location 实现的。
3、处理请求:一旦匹配到相应的 location 块,Nginx 就会根据该块中的配置处理请求。这可能涉及到静态文件服务、代理请求到后端服务器、重定向、返回错误页面等操作。
4、响应客户端:处理完请求后,Nginx 会生成一个响应并发送回客户端。
5. 正向代理 vs 反向代理的区别?Nginx属于哪种?
-
正向代理:代理服务器位于客户端与目标服务器之间。客户端通过代理服务器向目标服务器发送请求。目标服务器只能看到代理服务器的 IP 地址,而看不到客户端的真实 IP 地址。正向代理通常用于客户端访问互联网时,通过代理服务器来访问外部资源,这可以提高安全性和隐私保护。
-
反向代理:反向代理位于客户端和目标服务器之间,但与正向代理不同,客户端通常不知道反向代理的存在。反向代理隐藏了后端的真实服务器,对外表现为单一入口点。客户端无需知道后端的具体结构,所有请求都直接发送给反向代理服务器。后端服务器处理请求并将响应返回给反向代理服务器,反向代理服务器再将响应返回给客户端。
Nginx 主要用于反向代理场景,但也可以通过特定配置实现正向代理功能
6、使用“反向代理服务器”的优点是什么?
隐藏服务器:反向代理服务器可以隐藏后端服务器的存在和特征,这有助于提高安全性,因为外部用户无法直接访问后端服务器。负载均衡:反向代理可以作为负载均衡器,将流量分配到多个后端服务器,这样可以提高网站的可用性和扩展性。缓存静态内容:反向代理服务器可以缓存静态内容,如图片、CSS 和 JavaScript 文件等,这样可以减少后端服务器的负载并提高响应速度。SSL 终端:反向代理服务器可以处理 SSL/TLS 加密,这样可以减轻后端服务器的加密负担。
7、Nginx的优缺点?
优点:
高性能和高并发:Nginx 能够处理大量的并发连接,而内存消耗相对较小,这使得它在高流量场景下表现出色。静态文件处理:Nginx 在处理静态文件方面非常高效,它能够快速地提供图片、CSS、JavaScript 等静态资源。负载均衡:Nginx 可以作为负载均衡器,将流量分配到多个后端服务器,这样可以提高网站的可用性和扩展性。
动态处理能力:Nginx 在处理动态内容方面相对较弱,它更适合作为静态资源的服务器和反向代理。对于需要复杂动态处理的应用,可能需要与其他应用服务器(如 PHP、Node.js)配合使用。
8、Nginx应用场景?
HTTP 服务器:Nginx 可以作为 HTTP 服务器独立提供 HTTP 服务,适用于静态网站托管。反向代理和负载均衡:Nginx 可以作为反向代理服务器,将请求转发到后端服务器,并支持负载均衡,这对于高流量网站和应用来说非常重要。API 网关:Nginx 可以配置为 API 网关,对每个接口服务进行拦截和路由,提供额外的安全层和流量控制。邮件代理:Nginx 还可以作为邮件代理服务器,处理邮件传输。
9、Nginx配置文件nginx.conf有哪些属性模块?
events:定义了事件处理的配置,如工作连接数 worker_connections。
http:定义了 HTTP 服务器的配置,包括文件类型、默认类型、连接超时等。
server:定义了虚拟主机的配置,可以包含多个 server 块,每个块定义了一个虚拟主机的设置。
location:定义了请求的匹配和处理规则,可以根据 URI、正则表达式等匹配请求,并指定处理方式。
upstream:定义了负载均衡的配置,可以指定多个后端服务器,并设置负载均衡策略。
10、如何用Nginx解决前端跨域问题?
Nginx 可以通过配置 CORS(跨源资源共享)头部来解决前端跨域问题。以下是配置 CORS 的步骤:
在 server 或 location 块中,使用 add_header 指令添加 Access-Control-Allow-Origin 头部,指定允许访问的源。
如果需要,还可以添加 Access-Control-Allow-Methods 头部,指定允许的 HTTP 方法。
对于需要凭证的请求,可以添加 Access-Control-Allow-Credentials 头部。
11、Nginx虚拟主机怎么配置?
在 Nginx 中配置虚拟主机主要涉及 server 块的设置。以下是配置虚拟主机的步骤:定义 server 块:每个 server 块定义了一个虚拟主机的配置。
设置监听端口:使用 listen 指令设置服务器监听的端口,通常是 80(HTTP)和 443(HTTPS)。
设置服务器名称:使用 server_name 指令设置虚拟主机的域名。
定义 location 块:在 server 块内部定义 location 块,设置请求的处理规则。
设置根目录:使用 root 指令设置网站内容的根目录。
设置默认首页:使用 index 指令设置默认首页文件。
12、location的作用是什么?
location 指令在 Nginx 配置中扮演着核心角色,它定义了如何处理进入 Nginx 的 HTTP 请求。location 块可以匹配不同的 URI、正则表达式或指定的字符串,从而允许对特定的请求路径应用不同的处理规则。
精确匹配:使用 = 符号进行精确匹配,例如 location = / 匹配根路径。
字符串开头匹配:使用 ^~ 符号匹配以特定字符串开头的 URI。
正则表达式匹配:使用 ~ 或 ~* 符号进行正则表达式匹配,其中 ~ 是区分大小写的,而 ~* 是不区分大小写的。
通用匹配:使用 / 符号进行通用匹配,作为最后的选择,如果其他匹配都未成功,请求将被这个 location 块处理。
13. 如何配置Nginx实现负载均衡?常见的算法有哪些?
Nginx 支持多种负载均衡策略,包括但不限于:
- 轮询(Round Robin):默认方式,依次分配请求到各后端服务器 ty-reference。
- 加权轮询(Weighted Round Robin):根据权重分配请求,权重越大分配比例越高 ty-reference。
- IP Hash:基于客户端 IP 地址的哈希值分配请求,保证同一客户端总是被定向到同一台后端服务器 ty-reference。
- 最小连接数(Least Connections):将请求分发给当前连接数最少的服务器 ty-reference。
二、配置与调优
14. location匹配规则优先级(=、^、、~*、无符号)
Nginx 的 location
匹配遵循特定顺序:
=
:精确匹配,只有完全匹配路径才会生效。^~
:前缀匹配,一旦匹配成功则不再尝试正则表达式匹配。~
或~*
:区分大小写的正则匹配和不区分大小写的正则匹配。- 普通前缀匹配:最长前缀匹配原则
15. 如何实现URL重写(rewrite)?举例说明
Nginx 的 rewrite
指令允许你修改请求 URI,常用于 URL 重定向或内部转发:
server {rewrite ^/old-page/(.*)$ /new-page/$1 permanent; # 301永久重定向rewrite ^/user/(\d+)$ /user/profile?id=$1 last; # 内部转发
}
16. 如何限制Nginx的并发连接数?
http {# 定义限制区域:以客户端IP为键,分配10MB内存存储状态limit_conn_zone $binary_remote_addr zone=addr:10m;server {location / {# 每个IP同时最多允许100个连接limit_conn addr 100;# 超出限制返回503错误limit_conn_status 503;}}
}
17. 如何配置HTTPS?SSL证书如何加载?
server {listen 443 ssl;server_name example.com;# SSL证书路径(PEM格式)ssl_certificate /etc/nginx/ssl/example.com.crt;ssl_certificate_key /etc/nginx/ssl/example.com.key;# 优化SSL配置ssl_protocols TLSv1.2 TLSv1.3;ssl_ciphers ECDHE-ECDSA-AES128-GCM-SHA256:ECDHE-RSA-AES128-GCM-SHA256;ssl_prefer_server_ciphers on;ssl_session_cache shared:SSL:10m;ssl_session_timeout 10m;
}
18、Nginx配置高可用性怎么配置?
配置 Nginx 以实现高可用性主要涉及确保 Nginx 能够处理后端服务器的故障,并在必要时将流量重定向到健康的服务器。以下是一些关键的配置步骤:定义多个后端服务器:在 upstream 块中定义多个服务器,以便在一个服务器失败时有备用服务器可用。
设置超时参数:配置 proxy_connect_timeout、proxy_send_timeout 和 proxy_read_timeout 指令,以便在后端服务器无响应时及时失败转移。
使用 max_fails 和 fail_timeout:配置 max_fails 指令来设置在多长时间内允许多少次失败,以及 fail_timeout 指令来设置服务器失败后应该被排除在外的时间。
三、故障排查与性能优化
19. Nginx的access_log和error_log的作用是什么?如何分析日志?
access_log:记录客户端请求信息,如 IP、时间、请求方法、状态码、响应大小。示例日志格式:192.168.1.1 - - [10/Oct/2023:14:30:01 +0800] "GET /index.html HTTP/1.1" 200 612 "-" "Mozilla/5.0"
常用分析命令:
error_log:记录 Nginx 运行时的错误信息(如配置错误、后端超时、权限问题)。日志级别:debug | info | notice | warn | error | crit(默认 error)。# 实时查看访问日志
tail -f /var/log/nginx/access.log# 统计状态码为502的请求
grep ' 502 ' /var/log/nginx/access.log | awk '{print $1, $7}'# 查找错误日志中的超时错误
grep 'upstream timed out' /var/log/nginx/error.log
20. 502 Bad Gateway错误可能的原因?如何排查?
可能原因:后端服务未启动或崩溃。反向代理配置错误(如后端地址错误、端口未监听)。后端服务处理超时(Nginx 的 proxy_read_timeout 设置过短)。防火墙或网络问题导致 Nginx 无法连接后端。
排查步骤:检查Nginx error_log:grep "502" /var/log/nginx/error.log。验证后端服务状态:curl -v http://backend-server:port。检查网络连通性:telnet backend-server port 或 nc -zv backend-server port。
四、底层原理(加分项)
21. Nginx为什么比Apache更适合高并发场景?
架构模型:Apache:多进程/多线程模型(如 prefork、worker),每个连接占用一个线程,资源消耗高。Nginx:事件驱动 + 异步非阻塞模型,单个 Worker 处理数千连接,资源占用低。
内存消耗:Apache:每个连接约消耗 2MB~8MB 内存。Nginx:每个连接约消耗 2.5KB 内存。
22. 什么是惊群问题(Thundering Herd)?Nginx如何解决?
问题描述:多个进程/线程同时监听同一端口,当新连接到达时,所有进程被唤醒竞争资源,导致 CPU 资源浪费。Nginx 解决方案:使用 accept_mutex 锁(默认开启):同一时间只有一个 Worker 进程监听端口。当有新连接时,获得锁的 Worker 处理连接,其他 Worker 继续处理现有请求。
五、实战场景
23. 如何用Nginx实现动静分离?
server {# 静态资源(图片、CSS、JS)location ~* \.(jpg|png|css|js)$ {root /data/static;expires 30d; # 客户端缓存30天access_log off; # 关闭日志减少磁盘IO}# 动态请求(API)location /api {proxy_pass http://backend_server;proxy_set_header Host $host;}
}
24. 如何限制某个IP的访问频率?
http {# 定义限流区域:每秒10个请求(10r/s),突发允许20个请求limit_req_zone $binary_remote_addr zone=ip_limit:10m rate=10r/s;server {location / {limit_req zone=ip_limit burst=20 nodelay;# nodelay表示突发请求立即处理,不延迟}}
}
六、扩展问题
25. Nginx如何实现热部署(Reload)?
流程:执行 nginx -s reload 向 Master 进程发送 SIGHUP 信号。Master 检查新配置文件语法是否正确。若配置正确,启动新的 Worker 进程,并逐步关闭旧的 Worker。旧 Worker 处理完当前请求后退出,实现无缝切换。
相关文章:
Nginx 运维开发高频面试题详解
一、基础核心问题 原文链接:https://blog.csdn.net/weixin_51146329/article/details/142963853 1、什么是Nginx? Nginx 是一个高性能的 HTTP 和反向代理服务器,它以轻量级和高并发处理能力而闻名。Nginx 的反向代理功能允许它作为前端服务…...

下载OpenJDK
由于Oracle需要付费,并且之前我在寻找openJDK的时候,我不知道网址,并且也不知道在这个openjdk这个网址里点击哪个模块进行下载。最近我在看虚拟机相关的书籍的时候,找到了相关的网址。 注意:下面的下载都是基于可以科…...
Web3.js详解
Web1&Web2&Web3 以下是Web1、Web2和Web3的详细介绍,以及一个对比表格: Web1 定义:Web1指的是有着固定内容的非许可的开源网络。特点:在Web1时代,网站内容主要由网站管理员或创建者提供,用户只能…...

学习串行通信
本文来源: [8-1] 串口通信_哔哩哔哩_bilibili 智谱清言 ------------ 串口(Serial Port): 串口是一种应用非常广泛的通讯接口,串口成本低,容易使用,通信线路简单,可实现两个设…...

【leetcode强化练习·二叉树】同时运用两种思维解题
本文参考labuladong算法笔记[【强化练习】同时运用两种思维解题 | labuladong 的算法笔记] 有的题目可以同时用「遍历」和「分解问题」两种思路来解,你可以利用这些题目训练自己的思维。 559. N 叉树的最大深度 | 力扣 | LeetCode | 给定一个 N 叉树,…...

Rank-analysis-1.2——一款基于LCU API的排位分析工具,大四学生独立开发
LOL Rank Record Analysis:一款基于LCU API的排位分析工具,大四学生独立开发! 大家好!我是河南科技学院的大四学生,今天给大家分享一个我自己开发的软件——LOL Rank Record Analysis。这是一个基于 Riot 提供的 LCU …...

什么是门控循环单元?
一、概念 门控循环单元(Gated Recurrent Unit,GRU)是一种改进的循环神经网络(RNN),由Cho等人在2014年提出。GRU是LSTM的简化版本,通过减少门的数量和简化结构,保留了LSTM的长时间依赖…...

Google Chrome-便携增强版[解压即用]
Google Chrome-便携增强版 链接:https://pan.xunlei.com/s/VOI0OyrhUx3biEbFgJyLl-Z8A1?pwdf5qa# a 特点描述 √ 无升级、便携式、绿色免安装,即可以覆盖更新又能解压使用! √ 此增强版,支持右键解压使用 √ 加入Chrome增强…...

智慧园区综合管理系统如何实现多个维度的高效管理与安全风险控制
内容概要 在当前快速发展的城市环境中,智慧园区综合管理系统正在成为各类园区管理的重要工具,无论是工业园、产业园、物流园,还是写字楼与公寓,都在积极寻求如何提升管理效率和保障安全。通过快鲸智慧园区管理系统,用…...

【PyTorch】7.自动微分模块:开启神经网络 “进化之门” 的魔法钥匙
目录 1. 梯度基本计算 2. 控制梯度计算 3. 梯度计算注意 4. 小节 个人主页:Icomi 专栏地址:PyTorch入门 在深度学习蓬勃发展的当下,PyTorch 是不可或缺的工具。它作为强大的深度学习框架,为构建和训练神经网络提供了高效且灵活…...
从0开始使用面对对象C语言搭建一个基于OLED的图形显示框架(协议层封装)
目录 协议层设计,以IIC为例子 关于软硬件IIC 设计的一些原则 完成协议层的抽象 刨析我们的原理 如何完成我们的抽象 插入几个C语言小技巧 完成软件IIC通信 开始我们的IIC通信 结束我们的IIC通信 发送一个字节 (重要)完成命令传递和…...

Mac M1 源码安装FFmpeg,开启enable-gpl 和 lib x264
1、第一步:下载并安装minicoda curl -O https://repo.anaconda.com/miniconda/Miniconda3-latest-MacOSX-arm64.shsh Miniconda3-latest-MacOSX-arm64.sh2、第二步:安装必要的依赖 conda install -c conda-forge gcc make nasm yasm3、第三步ÿ…...

【Quest开发】手柄单手抓握和双手抓握物体切换
V72更新以后非常智能哈,配置物体简单多了。 选择需要被抓取的物体鼠标右键单击它,点Add Grab Interaction,按它要求的配置就行 配好以后长这样 把这个选项取消勾选就能切换成双手抓一个物体了,不需要像以前一样用各种grabTransfo…...

DB-GPT试用
继续上一篇 DB-GPT的安装 https://blog.csdn.net/berryreload/article/details/142845190 访问http://xxx:5670 访问这里 创建数据库连接 http://10.168.1.208:5670/construct/database 访问这里,点击刷新 http://10.168.1.208:5670/construct/app 刷新后才能出…...
《Ollama Python 库》
Ollama Python 库 Ollama Python 库提供了将 Python 3.8 项目与 Ollama 集成的最简单方法。 先决条件 应该安装并运行 Ollama拉取一个模型以与库一起使用:例如ollama pull <model>ollama pull llama3.2 有关可用模型的更多信息,请参阅 Ollama.com。…...
Java的Integer缓存池
Java的Integer缓冲池? Integer 缓存池主要为了提升性能和节省内存。根据实践发现大部分的数据操作都集中在值比较小的范围,因此缓存这些对象可以减少内存分配和垃圾回收的负担,提升性能。 在-128到 127范围内的 Integer 对象会被缓存和复用…...
Ubuntu16.04编译安装Cartographer 1.0版本
说明 官方文档 由于Ubuntu16.04已经是很老的系统,如果直接按照Cartographer官方安装文档安装会出现代码编译失败的问题,本文给出了解决这些问题的办法。正常情况下执行本文给出的安装方法即可成功安装。 依赖安装 # 这里和官方一致 # Install the req…...
Qt调用FFmpeg库实时播放UDP组播视频流
基于以下参考链接,通过改进实现实时播放UDP组播视频流 https://blog.csdn.net/u012532263/article/details/102736700 源码在windows(qt-opensource-windows-x86-5.12.9.exe)、ubuntu20.04.6(x64)(qt-opensource-linux-x64-5.12.12.run)、以…...
C# 类与对象详解
.NET学习资料 .NET学习资料 .NET学习资料 在 C# 编程中,类与对象是面向对象编程的核心概念。它们让开发者能够将数据和操作数据的方法封装在一起,从而构建出模块化、可维护且易于扩展的程序。下面将详细介绍 C# 中类与对象的相关知识。 一、类的定义 …...

【Elasticsearch 基础入门】Centos7下Elasticsearch 7.x安装与配置(单机)
Elasticsearch系列文章目录 【Elasticsearch 基础入门】一文带你了解Elasticsearch!!!【Elasticsearch 基础入门】Centos7下Elasticsearch 7.x安装与配置(单机) 目录 Elasticsearch系列文章目录前言单机模式1. 安装 J…...
利用ngx_stream_return_module构建简易 TCP/UDP 响应网关
一、模块概述 ngx_stream_return_module 提供了一个极简的指令: return <value>;在收到客户端连接后,立即将 <value> 写回并关闭连接。<value> 支持内嵌文本和内置变量(如 $time_iso8601、$remote_addr 等)&a…...

3.3.1_1 检错编码(奇偶校验码)
从这节课开始,我们会探讨数据链路层的差错控制功能,差错控制功能的主要目标是要发现并且解决一个帧内部的位错误,我们需要使用特殊的编码技术去发现帧内部的位错误,当我们发现位错误之后,通常来说有两种解决方案。第一…...

基于Flask实现的医疗保险欺诈识别监测模型
基于Flask实现的医疗保险欺诈识别监测模型 项目截图 项目简介 社会医疗保险是国家通过立法形式强制实施,由雇主和个人按一定比例缴纳保险费,建立社会医疗保险基金,支付雇员医疗费用的一种医疗保险制度, 它是促进社会文明和进步的…...
根据万维钢·精英日课6的内容,使用AI(2025)可以参考以下方法:
根据万维钢精英日课6的内容,使用AI(2025)可以参考以下方法: 四个洞见 模型已经比人聪明:以ChatGPT o3为代表的AI非常强大,能运用高级理论解释道理、引用最新学术论文,生成对顶尖科学家都有用的…...

AI书签管理工具开发全记录(十九):嵌入资源处理
1.前言 📝 在上一篇文章中,我们完成了书签的导入导出功能。本篇文章我们研究如何处理嵌入资源,方便后续将资源打包到一个可执行文件中。 2.embed介绍 🎯 Go 1.16 引入了革命性的 embed 包,彻底改变了静态资源管理的…...

Reasoning over Uncertain Text by Generative Large Language Models
https://ojs.aaai.org/index.php/AAAI/article/view/34674/36829https://ojs.aaai.org/index.php/AAAI/article/view/34674/36829 1. 概述 文本中的不确定性在许多语境中传达,从日常对话到特定领域的文档(例如医学文档)(Heritage 2013;Landmark、Gulbrandsen 和 Svenevei…...

Aspose.PDF 限制绕过方案:Java 字节码技术实战分享(仅供学习)
Aspose.PDF 限制绕过方案:Java 字节码技术实战分享(仅供学习) 一、Aspose.PDF 简介二、说明(⚠️仅供学习与研究使用)三、技术流程总览四、准备工作1. 下载 Jar 包2. Maven 项目依赖配置 五、字节码修改实现代码&#…...
JS手写代码篇----使用Promise封装AJAX请求
15、使用Promise封装AJAX请求 promise就有reject和resolve了,就不必写成功和失败的回调函数了 const BASEURL ./手写ajax/test.jsonfunction promiseAjax() {return new Promise((resolve, reject) > {const xhr new XMLHttpRequest();xhr.open("get&quo…...
LRU 缓存机制详解与实现(Java版) + 力扣解决
📌 LRU 缓存机制详解与实现(Java版) 一、📖 问题背景 在日常开发中,我们经常会使用 缓存(Cache) 来提升性能。但由于内存有限,缓存不可能无限增长,于是需要策略决定&am…...

LabVIEW双光子成像系统技术
双光子成像技术的核心特性 双光子成像通过双低能量光子协同激发机制,展现出显著的技术优势: 深层组织穿透能力:适用于活体组织深度成像 高分辨率观测性能:满足微观结构的精细研究需求 低光毒性特点:减少对样本的损伤…...