Nginx 代理后 web 网站接口变慢 5 秒?真相竟是一个被忽略的 Hosts 配置!
|
admin
2025年8月14日 22:42
本文热度 49
|
今天分享一个我踩到的“低级但致命”的性能坑:
Nginx 代理后接口响应从毫秒级变成 5 秒以上,而直接访问后端却很快!
查文档 各种调优参数都试了个遍,结果真相让我哭笑不得——竟然是因为 Nginx 的 server_name
配了 IP,但没配 Hosts 解析!
不信?一起来看完整排查过程👇
🐞 问题现象
- 部署方式:Nginx 反向代理,后端服务监听
127.0.0.1:8088
:通过 Nginx 访问接口,平均响应时间 5~6 秒!:直接访问 http://127.0.0.1:8088/api/user
,响应时间 < 50ms!
后端没问题,网络通,服务正常,那慢在哪?
排查思路:
第一步:排除后端
curl -w "TCP: %{time_connect}s, 耗时: %{time_total}s\n" \
-o /dev/null -s \
http:
第二步:检查 Nginx 配置(常规操作)
网上常见的“优化建议”我都试了:全都无效!😭
| | |
---|
proxy_buffering off | |
|
proxy_http_version 1.1 | |
|
keepalive_timeout | |
|
resolver | |
|
| |
|
第三步:抓包分析
F12开发模式查看请求时间线:

推测问题出在nginx响应阶段, Nginx 接收到请求后,并没有立即转发给后端只能这么推测, 因为已经排除后端了只能是nginx的问题
用 tcpdump
抓包:
tcpdump -i any -nn port 80
tcpdump -i any -nn port 8088
发现:Nginx 接收请求后,约 5 秒127.0.0.1:8088 才接受到请求猜测会不会是ip地址反向解析造成的,抱着试试看的心态搞一下试试
server_name
是 IP,莫非会触发反向解析?
由于我的服务器nginx server_name:配置的是IP地址, 了解到 nginx中也会走一遍host做反向解析, 推断出是反向解析导致的
给本机 IP 加 Hosts 解析
编辑 /etc/hosts
:
# 添加本机 IP 映射
192.168.1.100 localhost test-server
💡 替换 192.168.1.100
为你的服务器实际 IP。
然后重启 Nginx 或重载配置:
验证
再次访问接口:效果杠杠滴
✅ 问题解决!
✅ 最佳实践建议
生产环境建议使用域名
若用 IP,务必配 Hosts:
阅读原文:原文链接
该文章在 2025/8/15 12:11:41 编辑过