用 Nginx 日志驱动页面加载速度优化
一 建立可度量的日志基线
log_format perf '$remote_addr - $remote_user [$time_local] "$request" '
'$status $body_bytes_sent "$http_referer" "$http_user_agent" '
'$request_time $upstream_response_time $pipe $gzip_ratio '
'"$http_x_cache" $sent_http_content_type';
access_log /var/log/nginx/access.log perf;
error_log /var/log/nginx/error.log warn;
二 识别慢请求与瓶颈
awk '$NF > 1.0 {print $0}' /var/log/nginx/access.log | sort -kNF -nr | head -20
# 平均耗时与请求数
awk '{split($7,a,"?"); u=a[1]; t=$NF; sum[u]+=t; cnt[u]++;} END {for(i in sum) printf "%.3f %d %s\n", sum[i]/cnt[i], cnt[i], i}' \
/var/log/nginx/access.log | sort -nr | head
# 近似 P95(按耗时分桶)
awk '{n=int($NF*100); c[n]++;} END {for(i in c) print i/100, c[i]}' /var/log/nginx/access.log | sort -n
三 日志驱动的优化动作
proxy_cache_path /var/cache/nginx levels=1:2 keys_zone=STATIC:10m max_size=1g inactive=60m use_temp_path=off;
server {
location ~* \.(js|css|png|jpg|jpeg|gif|ico|svg)$ {
expires 1y; add_header Cache-Control "public, immutable";
proxy_cache STATIC;
proxy_pass http://backend_static;
}
location / {
proxy_cache STATIC;
proxy_pass http://backend_app;
proxy_cache_valid 200 302 10m;
proxy_cache_valid 404 1m;
}
}
http {
limit_req_zone $binary_remote_addr zone=api:10m rate=10r/s;
server {
location /api/ {
limit_req zone=api burst=20 nodelay;
}
}
}
四 监控 告警 与持续优化