Logrotate 是 Linux 下用 C 编写的日志轮转工具,非 Apache 或 Java 自带;按时间、大小、数量策略自动归档压缩日志,需配合 Java 应用注意文件句柄和信号重载。

Logrotate 不是 Apache 自带的工具,也不是 Java 实现的日志切分组件,而是 Linux 系统中广泛使用的、用 C 编写的日志轮转(rotation)工具。它与 Java 或 Apache 本身无直接依赖关系,但常被用来管理 Tomcat、Spring Boot(通过 logback/log4j 输出到文件)等 Java 应用产生的日志文件。
Logrotate 的核心作用
按时间(如每天)、大小(如超过 100MB)、数量(保留最近 7 份)等策略自动归档、压缩、删除旧日志,避免磁盘写满,同时便于排查问题。
典型 Java 应用日志路径识别
需先确认 Java 进程输出的日志文件位置,常见情况包括:
- Tomcat:通常为 $CATALINA_HOME/logs/catalina.out(控制台日志),或自定义的 access_log、localhost.* 等
- Spring Boot(使用 logback):若配置了
<file>logs/app.log</file>,则日志路径为项目目录下的 logs/app.log - Log4j2 配置中
fileName="logs/app.log"同理
⚠️ 注意:logrotate 只能管理「已写入磁盘的静态文件」,对标准输出重定向(如 java -jar app.jar > logs/app.log 2>&1)的日志有效;若应用内部用异步追加且未刷新缓冲区,可能短暂延迟可见。
立即学习 “Java 免费学习笔记(深入)”;
Logrotate 配置示例(以 Spring Boot 日志为例)
在 /etc/logrotate.d/myapp 中添加:
/path/to/myapp/logs/app.log {daily missingok rotate 7 compress delaycompress notifempty create 644 myuser mygroup sharedscripts postrotate # 若应用使用 reload 信号或脚本重启日志句柄(可选)# kill -USR1 `cat /path/to/myapp/app.pid 2>/dev/null` 2>/dev/null || true endscript}
关键参数说明:
- daily:每天轮转一次(也可用
weekly、size 100M) - missingok:日志文件不存在时不报错
- rotate 7:保留最近 7 个归档(如 app.log.1.gz ~ app.log.7.gz)
- compress + delaycompress:启用压缩,但最新一轮不立即压缩(方便调试)
- create 644 myuser mygroup:轮转后新建日志文件,并设权限和属主(确保 Java 进程有写权限)
- sharedscripts + postrotate:所有匹配文件处理完后执行一次脚本(适合通知应用重开日志文件)
Java 应用配合建议
Logrotate 本身不通知应用,因此需注意日志句柄是否仍指向已被重命名的旧文件(导致新日志丢失)。解决方式有:
- 推荐:使用支持外部信号的日志框架 Logback 支持
SIGHUP重载配置并重新打开文件;可在postrotate中发送:kill -HUP `cat /path/to/app.pid` 2>/dev/null || true - 替代:避免依赖标准文件输出 改用
logback-access(Web 容器)或 SLF4J + AsyncAppender + RollingFileAppender,并配置TimeBasedRollingPolicy,由 Java 框架自身完成切分(无需 logrotate) - 简单场景:重定向 + nohup + logrotate 启动命令:
nohup java -jar app.jar > logs/app.log 2>&1 &
此时 logrotate 可安全切分,但需确保create权限正确,否则新日志无法写入






























