news 2026/4/30 20:45:02

Nginx配置常见坑与性能调优

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
Nginx配置常见坑与性能调优

Nginx配置看起来简单,但坑真的多。

有些错误你可能永远发现不了(直到出事),有些错误会让你排查半天。整理一下常见的坑和调优经验。

proxy_pass结尾的斜杠

这个坑很常见。

# 前端请求 /api/users # 写法1 location /api { proxy_pass http://backend; } # 后端收到:/api/users # 写法2(多了个斜杠) location /api { proxy_pass http://backend/; } # 后端收到:/users ← /api没了!

就差一个斜杠,效果完全不一样。

简单记:proxy_pass后面带路径(包括单独的/),location匹配的部分会被替换掉;不带路径,原样转发。

location匹配不是你想的那样

location /api { proxy_pass http://backend; } location ~ /api/v[0-9]+ { proxy_pass http://backend-new; }

访问/api/v2/users,你觉得走哪个?

很多人以为按顺序,其实不是。正则匹配~优先于普通前缀匹配。所以走的是第二个。

但如果你想让某个路径不走正则

location ^~ /api/internal { # ^~ 会阻止后面的正则匹配 proxy_pass http://internal-backend; } location ~ /api { proxy_pass http://backend; }

^~前缀匹配的优先级比正则高。

完整优先级:=精确 >^~前缀 >~正则 > 普通前缀(取最长)

Vue/React项目刷新404

单页应用部署后,直接访问首页没问题,但刷新或直接访问子路由就404。

location / { root /var/www/dist; try_files $uri $uri/ /index.html; }

这个配置应该没问题,但还是404?

检查这几个:

1、index.html存在吗?

ls-la/var/www/dist/index.html

2、SELinux(CentOS的大坑)

getenforce# 如果是Enforcing# 临时关闭测试setenforce0# 或者正确设置contextchcon-R-thttpd_sys_content_t /var/www/dist

SELinux是CentOS上的常见坑。

502 Bad Gateway

高并发的时候出现502,后端其实没挂。

通常是upstream的连接数不够了。加上keepalive:

upstream backend { server 127.0.0.1:8080; keepalive 100; # 保持100个空闲连接 } location / { proxy_pass http://backend; proxy_http_version 1.1; proxy_set_header Connection ""; # 这行很重要 }

Connection ""是为了让Nginx用HTTP/1.1的keepalive,不然每次请求都新建连接。

上传大文件413

413 Request Entity Too Large

Nginx默认只允许1M的请求体:

client_max_body_size 100m;

放在http、server或location块都行。

WebSocket老断

WebSocket连上没多久就断了,通常是超时:

location /ws { proxy_pass http://backend; proxy_http_version 1.1; proxy_set_header Upgrade $http_upgrade; proxy_set_header Connection "upgrade"; # 关键:超时设成长一点 proxy_read_timeout 3600s; proxy_send_timeout 3600s; }

默认60秒没数据就断了,WebSocket要设长一点。

缓存设了不生效

location ~* \.(js|css|png)$ { expires 30d; }

配置了但浏览器还是每次都请求?

检查后端有没有返回Cache-Control: no-cache,这会覆盖你的设置。

location ~* \.(js|css|png)$ { proxy_pass http://backend; proxy_ignore_headers Cache-Control Expires; # 忽略后端的 expires 30d; }

性能调优

worker数量

worker_processes auto; # 自动等于CPU核数 events { worker_connections 10240; use epoll; multi_accept on; }

Gzip

gzip on; gzip_min_length 1k; # 太小的不压缩 gzip_comp_level 5; # 压缩级别,5够用了 gzip_types text/plain text/css application/json application/javascript;

静态文件

location ~* \.(js|css|png|jpg|gif|ico)$ { expires 1y; access_log off; # 静态文件不记日志,省IO }

sendfile

sendfile on; # 零拷贝 tcp_nopush on; # 合并小包 tcp_nodelay on;

常用配置模板

反向代理模板

server { listen 80; server_name api.example.com; location / { proxy_pass http://127.0.0.1:8080; proxy_http_version 1.1; 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_set_header X-Forwarded-Proto $scheme; } }

前端SPA模板

server { listen 80; server_name www.example.com; root /var/www/dist; location / { try_files $uri $uri/ /index.html; } location /api { proxy_pass http://127.0.0.1:8080; } location ~* \.(js|css|png|jpg|svg|woff2)$ { expires 1y; } }

调试技巧

检查配置

nginx-t# 语法检查nginx-T# 打印完整配置

打印变量

不确定变量值是什么的时候:

location /debug { return 200 "uri=$uri\nhost=$host\nargs=$args\n"; }

看连接状态

location /status { stub_status on; allow 127.0.0.1; deny all; }

然后curl localhost/status看当前连接数。


Nginx的坑基本就这些,配置的时候多注意斜杠、匹配顺序、超时时间,能避免大部分问题。

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/4/26 2:43:37

GB/T 7714-2015 CSL样式库:学术写作的智能解决方案

在学术写作过程中,参考文献格式的规范化处理往往成为研究者面临的一大挑战。GB/T 7714-2015 CSL样式库应运而生,为学者提供了一套完整的参考文献格式自动化工具,有效解决了格式调整的繁琐问题。 【免费下载链接】Chinese-STD-GB-T-7714-relat…

作者头像 李华
网站建设 2026/4/29 10:02:50

AndroidFaker隐私保护全攻略:打造无痕设备环境的终极方案

在当今数字时代,Android设备隐私保护已成为每个用户的迫切需求。AndroidFaker作为一款基于Xposed框架的隐私保护模块,能够有效伪造关键设备标识符,让你的设备信息彻底"隐身",告别设备追踪困扰。 【免费下载链接】Androi…

作者头像 李华
网站建设 2026/4/25 3:26:33

在接口测试中怎么处理开发是否提供接口文档的总结

最近做了好几个项目的接口自动化,接口测试很重要的参考依据就是接口文档,在自动化实施过程中碰到的接口文档也是千差万别,有的项目没有接口文档,有的项目有接口文档,有接口文档的项目,有的很完善&#xff0…

作者头像 李华
网站建设 2026/4/20 18:24:02

【Dify 架构优化必修课】:API格式统一的7个致命误区与破解之道

第一章:Dify API格式统一的核心价值 在构建现代化AI应用时,API接口的标准化与一致性直接影响开发效率、系统可维护性以及跨团队协作的顺畅程度。Dify通过统一API格式,为开发者提供了一套清晰、可预测的交互规范,显著降低了集成复杂…

作者头像 李华
网站建设 2026/4/30 17:45:46

MaaYuan:终极免费游戏自动化智能助手完整指南

MaaYuan:终极免费游戏自动化智能助手完整指南 【免费下载链接】MaaYuan 代号鸢 / 如鸢 一键长草小助手 项目地址: https://gitcode.com/gh_mirrors/ma/MaaYuan 你是否也曾为每天重复登录游戏、机械点击完成任务而感到疲惫?现代手游的日常任务系统…

作者头像 李华
网站建设 2026/4/23 16:58:39

Tecnotree入选Gartner®《创新洞察:AI安全运营中心(SOC)智能体加速通信服务提供商(CSP)安全运营转型》报告代表厂商

面向通信服务提供商(CSP)的全球数字平台和服务提供商Tecnotree今日宣布,公司与Google、Anthropic、Dropzone AI、DRUID、Palo Alto Networks和Pegasystems一道,被列为2025年12月发布的Gartner《创新洞察:AI安全运营中心智能体加速通信服务提供…

作者头像 李华