码迷,mamicode.com
首页 > 系统相关 > 详细

Linux日志文件总管——logrotate

时间:2018-04-12 15:32:40      阅读:178      评论:0      收藏:0      [点我收藏+]

标签:log 回滚

日志文件包含了关于系统中发生的事件的有用信息,在排障过程中或者系统性能分析时经常被用到。对于忙碌的服务器,日志文件大小会增长极快,服务器会很快消耗磁盘空间,这成了个问题。除此之外,处理一个单个的庞大日志文件也常常是件十分棘手的事。

假如有一个日志文件:
/var/log/log-file
我们对此日志文件进行切割
vim /etc/logrotate.d/log-file

/var/log/log-file {
    monthly
    size=50M
    rotate 5
    compress
    delaycompress
    missingok
    notifempty
    create 644 root root
    dateext
    postrotate
        /usr/bin/killall -HUP rsyslogd
    endscript
}
  • monthly: 日志文件将按月轮循。其它可用值为‘daily’,‘weekly’或者‘yearly’。
  • size=50M: 日志文件大于50M进行切割
  • rotate 5: 一次将存储5个归档日志。对于第六个归档,时间最久的归档将被删除。
  • compress: 在轮循任务完成后,已轮循的归档将使用gzip进行压缩。
  • delaycompress: 总是与compress选项一起用,delaycompress选项指示* logrotate不要将最近的归档压缩,压缩将在下一次轮循周期进行。这在你或任何软件仍然需要读取最新归档时很有用。
  • missingok: 在日志轮循期间,任何错误将被忽略,例如“文件无法找到”之类的错误。
  • notifempty: 如果日志文件为空,轮循不会进行。
  • create 644 root root: 以指定的权限创建全新的日志文件,同时logrotate也会重命名原始日志文件。
  • dateext: 以日期重命名备份文件
  • postrotate/endscript: 在所有其它指令完成后,postrotate和endscript里面指定的命令将被执行。在这种情况下,rsyslogd 进程将立即再次读取其配置并继续运行。

logrotate可以在任何时候从命令行手动调用。

要调用为/etc/lograte.d/下配置的所有日志调用logrotate:

#logrotate /etc/logrotate.conf
要为某个特定的配置调用logrotate:

#logrotate /etc/logrotate.d/log-file

Linux日志文件总管——logrotate

标签:log 回滚

原文地址:http://blog.51cto.com/11962757/2097378

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!