Java中Apache中日志切分工具Logrotate的配置方案

0次阅读

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

Java 中 Apache 中日志切分工具 Logrotate 的配置方案

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:每天轮转一次(也可用 weeklysize 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 权限正确,否则新日志无法写入

text=ZqhQzanResources