Nginx 日志轮转

在 Ubuntu 系统上,Nginx 日志不断增大(access.log / error.log) 是一个非常常见的问题。 如果不加限制,日志可能会几百 GB,占满磁盘。

如何排查、限制、自动轮转、删除旧日志


🧩 一、先确认日志路径和大小

默认情况下,Nginx 日志路径如下:

bash 复制代码
/var/log/nginx/access.log
/var/log/nginx/error.log

查看大小:

bash 复制代码
sudo du -h /var/log/nginx/*.log
复制代码

示例输出:

bash 复制代码
1.2G /var/log/nginx/access.log 500M /var/log/nginx/error.log

如果文件非常大(比如几 GB),说明日志没有被轮转。


🧰 二、检查 logrotate 是否启用

Ubuntu 系统自带 logrotate,默认会自动轮转 Nginx 日志。 配置文件在:

bash 复制代码
/etc/logrotate.d/nginx

查看内容:

bash 复制代码
cat /etc/logrotate.d/nginx

典型配置如下 👇

bash 复制代码
/var/log/nginx/*.log {
    daily
    missingok
    rotate 14
    compress
    delaycompress
    notifempty
    create 640 www-data adm
    sharedscripts
    postrotate
        if [ -f /run/nginx.pid ]; then
            kill -USR1 `cat /run/nginx.pid`
        fi
    endscript
}

解释:

|------------|-------------------|
| 配置项 | 说明 |
| daily | 每天轮转一次 |
| rotate 14 | 保留 14 天的日志 |
| compress | 自动 gzip 压缩旧日志 |
| notifempty | 空文件不处理 |
| postrotate | 通知 Nginx 重新打开日志文件 |


🧮 三、手动测试日志轮转是否工作

运行:

bash 复制代码
sudo logrotate -f /etc/logrotate.d/nginx

执行后,你应该看到:

  • 生成了 access.log.1access.log.1.gz

  • 原始的 access.log 重新创建,文件大小变小

查看结果:

bash 复制代码
ls -lh /var/log/nginx/

⚙️ 四、如果日志没有轮转(常见原因)

|-----------------------------|---------------------------------------------|
| 原因 | 解决方案 |
| /etc/logrotate.d/nginx 文件缺失 | 重新创建(见上面的示例) |
| Nginx PID 路径不同 | 修改 postrotate 里的路径,比如 /var/run/nginx.pid |
| 权限问题 | 确保 /var/log/nginx 属于 www-data:adm 或 root 可写 |
| logrotate 服务没启用 | 查看:systemctl status logrotate.timer |

启用定时器:

复制代码

sudo systemctl enable --now logrotate.timer


🧯 五、清理旧日志(节省磁盘空间)

手动删除旧的压缩日志:

sudo find /var/log/nginx -name "*.gz" -type f -mtime +14 -delete

删除超过 14 天的日志归档。

或者彻底清空日志(危险操作前请确认):

sudo truncate -s 0 /var/log/nginx/access.log sudo truncate -s 0 /var/log/nginx/error.log


🧩 六、减少日志体积(优化写入)

如果访问量极大,可通过 Nginx 配置减少日志写入。

编辑:

sudo nano /etc/nginx/nginx.conf

找到:

access_log /var/log/nginx/access.log;

改为:

# 1️⃣ 禁止日志(不推荐生产) # access_log off; # 2️⃣ 或只记录错误级别高的日志 error_log /var/log/nginx/error.log warn;

重启 Nginx:

sudo systemctl reload nginx


📊 七、推荐最终配置模板(放在 /etc/logrotate.d/nginx

/var/log/nginx/*.log { daily missingok rotate 14 compress delaycompress notifempty create 640 www-data adm sharedscripts postrotate [ -f /run/nginx.pid ] && kill -USR1 `cat /run/nginx.pid` endscript }


✅ 八、总结

|----------|-----------------------------------------------------------|
| 操作 | 命令 |
| 查看日志大小 | sudo du -h /var/log/nginx/*.log |
| 手动轮转 | sudo logrotate -f /etc/logrotate.d/nginx |
| 清空日志 | sudo truncate -s 0 /var/log/nginx/access.log |
| 删除旧日志 | sudo find /var/log/nginx -name "*.gz" -mtime +14 -delete |
| 启用自动轮转服务 | sudo systemctl enable --now logrotate.timer |


相关推荐
云飞云共享云桌面3 分钟前
研发部门使用SolidWorks和ug,cad,设计共享云桌面应该怎么选?
运维·服务器·网络·人工智能·3d
麦聪聊数据7 分钟前
数据库安全与运维管控(五):基于AST的SQL拦截与动态审批
运维·数据库·sql
亚空间仓鼠9 分钟前
OpenEuler系统常用服务(十)
linux·运维·服务器·网络
艾莉丝努力练剑9 分钟前
【Linux线程】Linux系统多线程(四):线程ID及进程地址空间布局,线程封装
java·linux·运维·服务器·c语言·c++·学习
同聘云9 分钟前
阿里云国际站 服务器的“客户端” (Client) 和 “服务器” (Server)到底是什么?有什么区别?
服务器·网络·阿里云·云计算·云小强
邓霖涛11 分钟前
nginx使用openSSL自签生成https相关证书
服务器·nginx·https
程序员老邢21 分钟前
【技术底稿 10】16G Ubuntu 服务器手动部署 Ollama 0.20.4 全流程(避坑 HTTP2 错误)
服务器·ubuntu·ai·语言模型·devops
饼瑶22 分钟前
Isaac Sim 5.0.0 Docker 部署手册(实验室服务器)
服务器·docker·容器
dddddppppp12322 分钟前
linux head.s 从第一条指令到start_kernel
linux·运维·服务器
BioRunYiXue23 分钟前
AlphaGenome:DeepMind 新作,基因组学迎来 Alpha 时刻
java·linux·运维·网络·数据库·人工智能·eclipse