对于 logrotate,我有一个每小时运行一次的 cron 任务。
在 logrotate.conf 中有指令“daily”。但日志文件每小时轮换一次,而不是每天轮换一次。
为什么会发生这种情况?这个指令有什么用?我认为这些与时间相关的指令比工具执行的轮换频率更低。
$ cat /opt/etc/logrotate.conf
compress
/opt/var/log/dir300.log {
daily
rotate 29
postrotate
killall -HUP syslog-ng
endscript
}
。
$ grep logrotate /opt/etc/crontab
50 */1 * * * admin /opt/sbin/logrotate -f /opt/etc/logrotate.conf &>/dev/null
$ ls -l dir300.log*
-rw------- 1 admin root 159856 2013-01-08 11:29 dir300.log
-rw------- 1 admin root 6838 2013-01-08 01:50 dir300.log.10.gz
-rw------- 1 admin root 20 2013-01-08 00:50 dir300.log.11.gz
-rw------- 1 admin root 592 2013-01-07 23:50 dir300.log.12.gz
-rw------- 1 admin root 124 2013-01-07 22:50 dir300.log.13.gz
-rw------- 1 admin root 20 2013-01-07 21:50 dir300.log.14.gz
-rw------- 1 admin root 20 2013-01-07 20:50 dir300.log.15.gz
-rw------- 1 admin root 107 2013-01-07 19:50 dir300.log.16.gz
-rw------- 1 admin root 20 2013-01-07 18:50 dir300.log.17.gz
-rw------- 1 admin root 20 2013-01-07 17:50 dir300.log.18.gz
-rw------- 1 admin root 20 2013-01-07 16:50 dir300.log.19.gz
-rw------- 1 admin root 14158 2013-01-08 10:50 dir300.log.1.gz
-rw------- 1 admin root 20 2013-01-07 15:50 dir300.log.20.gz
-rw------- 1 admin root 20 2013-01-07 14:50 dir300.log.21.gz
-rw------- 1 admin root 133 2013-01-07 13:50 dir300.log.22.gz
-rw------- 1 admin root 20 2013-01-07 12:50 dir300.log.23.gz
-rw------- 1 admin root 279 2013-01-07 11:50 dir300.log.24.gz
-rw------- 1 admin root 20 2013-01-07 10:50 dir300.log.25.gz
-rw------- 1 admin root 20 2013-01-07 09:50 dir300.log.26.gz
-rw------- 1 admin root 20 2013-01-07 08:50 dir300.log.27.gz
-rw------- 1 admin root 20 2013-01-07 07:50 dir300.log.28.gz
-rw------- 1 admin root 20 2013-01-07 06:50 dir300.log.29.gz
-rw------- 1 admin root 14236 2013-01-08 09:50 dir300.log.2.gz
-rw------- 1 admin root 14135 2013-01-08 08:50 dir300.log.3.gz
-rw------- 1 admin root 14349 2013-01-08 07:50 dir300.log.4.gz
-rw------- 1 admin root 14396 2013-01-08 06:50 dir300.log.5.gz
-rw------- 1 admin root 14268 2013-01-08 05:50 dir300.log.6.gz
-rw------- 1 admin root 14148 2013-01-08 04:50 dir300.log.7.gz
-rw------- 1 admin root 14347 2013-01-08 03:50 dir300.log.8.gz
-rw------- 1 admin root 14225 2013-01-08 02:50 dir300.log.9.gz
。
$ ipkg list logrotate
logrotate - 3.7.5-2 - Rotates, compresses, removes and mails system log files.
答案1
这是因为您正在使用-f
下面的 cron 作业命令强制日志轮换:
50 */1 * * * admin /opt/sbin/logrotate -f /opt/etc/logrotate.conf &>/dev/null
如果你阅读man logrotate
并查看以下段落:
-f, --force
告诉 logrotate 强制轮换,即使它认为没有必要。有时在将新条目添加到 logrotate 配置文件后,或者手动删除旧日志文件后,这很有用,因为将创建新文件,并且日志记录将继续正确进行。
从创建文件的时间戳可以清楚地看出这一点。如果你查看以下一些文件:
-rw------- 1 admin root 14349 2013-01-08 07:50 dir300.log.4.gz
-rw------- 1 admin root 14396 2013-01-08 06:50 dir300.log.5.gz
-rw------- 1 admin root 14268 2013-01-08 05:50 dir300.log.6.gz
-rw------- 1 admin root 14148 2013-01-08 04:50 dir300.log.7.gz
-rw------- 1 admin root 14347 2013-01-08 03:50 dir300.log.8.gz
-rw------- 1 admin root 14225 2013-01-08 02:50 dir300.log.9.gz
您可以轻松看到,每次执行 cron 任务都会创建一个新文件。同样,这是因为选项-f
。