logrotate是个十分有用的工具,它可以自动对日志进行截断(或轮循)、压缩以及删除旧的日志文件,例如,你可以设置logrotate,让/var/log/foo日志文件每30天轮循,并删除超过6个月的日志。配置完后,logrotate的运作完全自动化,不必进行任何进一步的人为干预。
安装:
#yum install logrotate crontabs
logrotate的配置文件是/etc/logrotate.conf,通常不需要对它进行修改。日志文件的轮循设置在独立的配置文件中,它(们)放在/etc/logrotate.d/目录下。
实列:
我们从创建一个日志文件开始吧,然后在其中填入一个10MB的随机比特流数据。
- # touch /var/log/log-file
- # head -c 10M < /dev/urandom > /var/log/log-file
由于现在日志文件已经准备好,我们将配置logrotate来轮循该日志文件。让我们为该文件创建一个配置文件。
- # vim /etc/logrotate.d/log-file
- /var/log/log-file {
- monthly
- rotate 5
- compress
- delaycompress
- missingok
- notifempty
- create 644 root root
- postrotate
- /usr/bin/killall -HUP rsyslogd
- endscript
- }
- monthly: 日志文件将按月轮循。其它可用值为‘daily’,‘weekly’或者‘yearly’。
- rotate 5: 一次将存储5个归档日志。对于第六个归档,时间最久的归档将被删除。
- compress: 在轮循任务完成后,已轮循的归档将使用gzip进行压缩
- delaycompress: 总是与compress选项一起用,delaycompress选项指示logrotate不要将最近的归档压缩,压缩将在下一次轮循周期进行。这在你或任何软件仍然需要读取最新归档时很有用。
- missingok: 在日志轮循期间,任何错误将被忽略,例如“文件无法找到”之类的错误。
- notifempty: 如果日志文件为空,轮循不会进行。
- create 644 root root: 以指定的权限创建全新的日志文件,同时logrotate也会重命名原始日志文件。
- postrotate/endscript: 在所有其它指令完成后,postrotate和endscript里面指定的命令将被执行。在这种情况下,rsyslogd 进程将立即再次读取其配置并继续运行。
实列2
我们想要让旧日志文件以创建日期命名,这可以通过添加dateext常熟实现
# vim /etc/logrotate.d/log-file
- /var/log/log-file {
- monthly
- rotate 5
- dateext
- create 644 root root
- postrotate
- /usr/bin/killall -HUP rsyslogd
- endscript
- }
命令:
#logrotate /etc/logrotate.d/file
参数:
-f 强制
-d 测试