Nginx 代理后 web 网站接口变慢 5 秒?真相竟是一个被忽略的 Hosts 配置!
				
									
					
					
						 | 
						
							
							admin 
							
							
								2025年8月14日 22:42
								本文热度 1915
							
							 
						 | 
					
					
				 
				
今天分享一个我踩到的“低级但致命”的性能坑:
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 编辑过