Nginx 代理后 web 网站接口变慢 5 秒?真相竟是一个被忽略的 Hosts 配置!
今天分享一个我踩到的“低级但致命”的性能坑:
Nginx 代理后接口响应从毫秒级变成 5 秒以上,而直接访问后端却很快!
查文档 各种调优参数都试了个遍,结果真相让我哭笑不得——竟然是因为 Nginx 的 server_name 配了 IP,但没配 Hosts 解析!
不信?一起来看完整排查过程👇
127.0.0.1:8088http://127.0.0.1:8088/api/user,响应时间 < 50ms!
后端没问题,网络通,服务正常,那慢在哪?
curl 直接请求本地服务:curl -w "TCP: %{time_connect}s, 耗时: %{time_total}s\n" \ -o /dev/null -s \http://127.0.0.1:8088/api/aa/test
网上常见的“优化建议”我都试了:全都无效!😭
proxy_buffering off | ||
proxy_http_version 1.1 | ||
keepalive_timeout | ||
resolver | ||
gzip |
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做反向解析, 推断出是反向解析导致的
立即查看 /etc/hosts编辑 /etc/hosts:
bash 深色版本
# 添加本机 IP 映射
192.168.1.100 localhost test-server
💡 替换
192.168.1.100为你的服务器实际 IP。
然后重启 Nginx 或重载配置:
bash 深色版本
nginx -s reload
再次访问接口:效果杠杠滴

✅ 问题解决!
生产环境建议使用域名
server_name api.aa.com;若用 IP,务必配 Hosts:
192.168.11.11 nginx-web
阅读原文:原文链接