在 Debian 系统中,配置 nohup 命令生成的日志文件的轮转可以通过 logrotate 工具来实现。以下是详细的步骤:
首先,确保你的应用程序使用 nohup 命令生成日志文件,并且这些日志文件的路径是固定的。例如:
nohup your_application > /var/log/your_application.log 2>&1 &
logrotate 的配置文件通常位于 /etc/logrotate.d/ 目录下。你可以创建一个新的配置文件来管理你的日志文件。
sudo nano /etc/logrotate.d/your_application
在新创建的配置文件中,添加以下内容:
/var/log/your_application.log {
daily
missingok
rotate 7
compress
notifempty
create 640 root adm
}
解释一下这些选项的含义:
daily: 每天轮转日志文件。missingok: 如果日志文件不存在,不会报错。rotate 7: 保留最近7天的日志文件。compress: 压缩旧的日志文件。notifempty: 如果日志文件为空,不进行轮转。create 640 root adm: 创建新的日志文件时,设置权限为640,属主为root,属组为adm。你可以手动测试 logrotate 配置是否正确:
sudo logrotate -f /etc/logrotate.d/your_application
这个命令会强制 logrotate 处理指定的配置文件,并应用轮转。
logrotate 通常会每天自动运行一次,检查并处理需要轮转的日志文件。你可以通过查看 /etc/cron.daily/logrotate 文件来确认这一点。
你可以查看 /var/log/your_application.log.* 文件来确认日志文件是否被正确轮转和压缩。
假设你的应用程序生成的日志文件是 /var/log/myapp.log,以下是一个完整的 logrotate 配置示例:
/var/log/myapp.log {
daily
missingok
rotate 7
compress
notifempty
create 640 root adm
}
保存并退出编辑器后,手动测试配置:
sudo logrotate -f /etc/logrotate.d/myapp
这样,你的 nohup 日志文件就会按照配置进行轮转了。