管理杂谈OA答疑ERP答疑教程搜索

Nginx 代理后 web 网站接口变慢 5 秒?真相竟是一个被忽略的 Hosts 配置!


今天分享一个我踩到的“低级但致命”的性能坑:

Nginx 代理后接口响应从毫秒级变成 5 秒以上,而直接访问后端却很快!

查文档 各种调优参数都试了个遍,结果真相让我哭笑不得——竟然是因为 Nginx 的 server_name 配了 IP,但没配 Hosts 解析!

不信?一起来看完整排查过程👇


🐞 问题现象

:通过 Nginx 访问接口,平均响应时间 5~6 秒
:直接访问 http://127.0.0.1:8088/api/user,响应时间 < 50ms

 后端没问题,网络通,服务正常,那慢在哪?


 排查思路:

第一步:排除后端

curl  -"TCP: %{time_connect}s, 耗时: %{time_total}s\n" \ -o  /dev/null -s \http://127.0.0.1:8088/api/aa/test
结果:总耗时 0.03s,排除后端到问题。


第二步:检查 Nginx 配置(常规操作)

网上常见的“优化建议”我都试了:全都无效!😭

优化项
结果

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做反向解析, 推断出是反向解析导致的


给本机 IP 加 Hosts 解析

编辑 /etc/hosts

bash

深色版本

# 添加本机 IP 映射
192.168.1.100  localhost test-server

💡 替换 192.168.1.100 为你的服务器实际 IP。

然后重启 Nginx 或重载配置:

bash

深色版本

nginx -s reload

 验证

再次访问接口:效果杠杠滴

✅ 问题解决!


✅ 最佳实践建议

  1. 生产环境建议使用域名

    server_name api.aa.com;
  2. 若用 IP,务必配 Hosts

    192.168.11.11   nginx-web

阅读原文:原文链接


更多精彩文章浏览...
点击右上角图标分享到朋友圈
官方网站:http://www.clicksun.cn
咨询热线:400-186-1886
服务邮箱:service@clicksun.cn