当前位置: 首页 > news >正文

Nginx 日志轮转

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

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


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

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

/var/log/nginx/access.log
/var/log/nginx/error.log

查看大小:

sudo du -h /var/log/nginx/*.log

示例输出:

1.2G /var/log/nginx/access.log 500M /var/log/nginx/error.log

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


🧰 二、检查 logrotate 是否启用

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

/etc/logrotate.d/nginx

查看内容:

cat /etc/logrotate.d/nginx

典型配置如下 👇

/var/log/nginx/*.log {dailymissingokrotate 14compressdelaycompressnotifemptycreate 640 www-data admsharedscriptspostrotateif [ -f /run/nginx.pid ]; thenkill -USR1 `cat /run/nginx.pid`fiendscript
}

解释:

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

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

运行:

sudo logrotate -f /etc/logrotate.d/nginx

执行后,你应该看到:

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

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

查看结果:

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

http://www.dtcms.com/a/511190.html

相关文章:

  • 《Linux运维总结:基于ARM64+X86_64架构CPU使用docker-compose一键离线部署mongodb 7.0.22容器版副本集群》
  • 《Linux运维总结:基于ARM64+X86_64架构CPU使用docker-compose一键离线部署mongodb 7.0.22容器版分片集群》
  • MongoDB基础与Mongoose ODM
  • 做定制网站价格教做flash的网站
  • 【流量控制】算不对 GBN 窗口?分不清 SR 重传?滑动窗口 + 3 大协议一篇吃透
  • 临时插入的紧急任务如何影响整体进度
  • 国内net开发的网站建设网站建设费如何会计处理
  • Melos 使用指南:Flutter / Dart 多包管理工具!
  • React组件完全指南
  • TypeScript:npm的types、typings、@type的区别
  • 我的第一份开源贡献:小米工程师程赛的社区之旅
  • Python 基础 | 第八课:函数详解与应用
  • 火狐浏览器替换js脚本
  • 车载诊断架构 --- 由一个售后问题引发对P4时间的思考
  • 第3章 SQL数据定义语句
  • phpcms 网站m8 wordpress主题
  • Docker到Kubernetes的平滑迁移(服务网格实战)
  • 数据挖掘知识体系分析
  • 简述网站建设的五类成员做电商网站公司
  • 数据结构——邻接表
  • 预算系统 - 项目优化点
  • 【软考备考】论软件架构设计-范文示例
  • 探讨一下java将来未来两年内的就业以及发展
  • [特殊字符] 已发布目标检测数据集合集(持续更新)
  • mysql主从延迟
  • 乌当区城乡建设局网站wordpress小工具下载
  • 网站后台不能上传2345应用商店
  • HTTPS与HTPP的区别
  • 链式结构二叉树:结点定义、创建及全操作实现(遍历 / 计数 / 销毁 / 判断完全二叉树)
  • android在sd卡中可以mkdir, 但是不可以createNewFile