在 CentOS 系统中,Java 应用程序的日志轮转通常是通过 logrotate 工具来实现的。要配置 Java 日志轮转,请按照以下步骤操作:
sudo yum install logrotate
/etc/logrotate.d/
目录下创建一个新的配置文件,例如 java_app
:sudo vi /etc/logrotate.d/java_app
/path/to/your/java/app/logs/*.log {
daily
rotate 7
compress
missingok
notifempty
create 640 root root
postrotate
if [ -f /path/to/your/java/app/logs/your_app.log.pid ]; then
kill -USR1 `cat /path/to/your/java/app/logs/your_app.log.pid`
fi
endscript
}
请将 /path/to/your/java/app/logs/
替换为您的 Java 应用程序日志文件的实际路径,将 your_app.log.pid
替换为实际的 PID 文件名。
这里的配置选项解释如下:
daily
: 每天轮转日志。rotate 7
: 保留 7 个轮转后的日志文件。compress
: 压缩轮转后的日志文件。missingok
: 如果日志文件不存在,不会产生错误。notifempty
: 如果日志文件为空,不进行轮转。create 640 root root
: 创建新的日志文件,权限为 640,属主为 root,属组为 root。postrotate
和 endscript
之间的脚本会在日志轮转后执行。这里我们向 Java 应用程序发送 USR1 信号,通知它重新打开日志文件。保存并退出配置文件。
测试 logrotate 配置是否正确:
sudo logrotate -f /etc/logrotate.d/java_app
这将强制执行一次日志轮转,您可以在 /path/to/your/java/app/logs/
目录下查看轮转后的日志文件。
现在,logrotate 将根据您的配置自动轮转 Java 应用程序的日志文件。
辰迅云「云服务器」,即开即用、新一代英特尔至强铂金CPU、三副本存储NVMe SSD云盘,价格低至29元/月。点击查看>>
推荐阅读: 如何从 dmesg 日志中发现硬件故障