首先检查系统资源使用情况,通过top、free -h、iostat和vmstat命令确认CPU、内存、磁盘I/O是否存在瓶颈;接着分析网络连接,利用netstat、ss和压测工具排查网络拥塞或连接异常;然后启用Nginx日志记录$request_time和$upstream_response_time,区分延迟源于Nginx自身还是后端服务;再优化Nginx配置,包括开启gzip压缩、合理设置worker进程与连接数、启用keepalive、配置静态资源缓存及限流;最后检查后端服务响应,通过日志和直接访问测试定位慢源,优化数据库查询与API性能,并引入Redis等缓存减轻负载。

当发现Nginx在Linux系统中出现高延迟时,需从网络、系统资源、Nginx配置和应用逻辑多个层面逐步排查。以下是具体的排查方法与优化建议。
检查服务器资源使用情况
高延迟常源于CPU、内存或I/O瓶颈。使用以下命令快速查看系统状态:
- top 或 htop:观察CPU占用率,确认是否有进程占满CPU。
- free -h:检查内存是否耗尽,是否存在频繁swap交换。
- iostat -x 1:查看磁盘I/O延迟(%util接近100表示磁盘过载)。
- vmstat 1:监控系统整体性能,si/so高说明内存压力大。
若资源紧张,应先扩容或优化后端服务,避免Nginx因等待上游响应而延迟升高。
分析网络连接与请求处理
Nginx延迟可能来自网络拥塞或连接处理不当:
- 使用netstat -s查看TCP重传、丢包等统计,重传率高说明网络不稳定。
- 用ss -tuln | grep :80确认Nginx监听正常,连接数是否异常。
- 通过ab(Apache Bench)或wrk进行压测,模拟并发请求,观察延迟变化。
- 启用Nginx的access_log记录$request_time和$upstream_response_time,定位慢请求是Nginx自身处理慢还是后端服务延迟。
若$request_time远大于$upstream_response_time,问题在Nginx本身;反之则问题在后端(如PHP、Python服务)。
优化Nginx配置提升性能
不合理配置会显著影响响应速度,重点调整以下参数:
- 开启gzip压缩:减少传输体积,加快页面加载。
gzip on; gzip_types text/plain text/css application/json application/javascript;
- 调整worker_processes为CPU核心数,worker_connections根据负载设置(通常4096以上)。
- 启用keepalive复用连接:
keepalive_timeout 65; keepalive_requests 100;
- 静态资源使用expires缓存,减轻重复请求压力:
location ~* \.(jpg|jpeg|png|css|js)$ { expires 30d; add_header Cache-Control "public"; } - 限制连接频率防攻击:limit_conn 和 limit_req 模块控制单IP请求。
检查后端服务与依赖响应
Nginx常作为反向代理,延迟多由后端慢引起:
- 查看日志中$upstream_response_time是否持续偏高。
- 直接访问后端服务(如curl后端接口),排除Nginx干扰。
- 检查数据库查询是否慢,API是否同步阻塞。
- 考虑引入缓存(Redis/Memcached)降低后端负载。
对于动态内容,可结合Nginx缓存加速:
proxy_cache_path /tmp/nginx_cache levels=1:2 keys_zone=my_cache:10m max_size=1g;
location / {
proxy_cache my_cache;
proxy_pass http://backend;
}
基本上就这些。从系统到网络再到配置层层排查,多数Nginx高延迟问题都能定位并解决。关键是用数据说话,别凭感觉调参。










