LOGO OA教程 ERP教程 模切知识交流 PMS教程 CRM教程 开发文档 其他文档  
 
网站管理员

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

admin
2025年8月14日 22:42 本文热度 49

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

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

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

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


🐞 问题现象

  • 项目:Java Spring Boot 应用
  • 部署方式:Nginx 反向代理,后端服务监听 127.0.0.1:8088

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

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


 排查思路:

第一步:排除后端

  • 使用 curl 直接请求本地服务:

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开发模式查看请求时间线:

  • F12开发模式 查看时间
    :5.12s ❗

推测问题出在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
     中没有配置本机 IP 的解析

给本机 IP 加 Hosts 解析

编辑 /etc/hosts

bash

深色版本

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

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

然后重启 Nginx 或重载配置:

bash

深色版本

nginx -s reload

 验证

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

  • 响应时间从 5.12s → 0.02s!
  • Chrome 开发模式显示正常

✅ 问题解决!


✅ 最佳实践建议

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

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

    192.168.11.11   nginx-web


阅读原文:原文链接


该文章在 2025/8/15 12:11:41 编辑过
关键字查询
相关文章
正在查询...
点晴ERP是一款针对中小制造业的专业生产管理软件系统,系统成熟度和易用性得到了国内大量中小企业的青睐。
点晴PMS码头管理系统主要针对港口码头集装箱与散货日常运作、调度、堆场、车队、财务费用、相关报表等业务管理,结合码头的业务特点,围绕调度、堆场作业而开发的。集技术的先进性、管理的有效性于一体,是物流码头及其他港口类企业的高效ERP管理信息系统。
点晴WMS仓储管理系统提供了货物产品管理,销售管理,采购管理,仓储管理,仓库管理,保质期管理,货位管理,库位管理,生产管理,WMS管理系统,标签打印,条形码,二维码管理,批号管理软件。
点晴免费OA是一款软件和通用服务都免费,不限功能、不限时间、不限用户的免费OA协同办公管理系统。
Copyright 2010-2025 ClickSun All Rights Reserved