logrotate---日志轮转

1) 什么是logrotate?

logrotate是一个日志管理程序,用来把旧的日志文件删除(备份),并创建新的日志文件,这个过程称为“转储”。我们可以根据日志的大小,或者根据其使用的天数来转储,这个过程一般由cron来执行。

      logrotate还可以用于压缩日志文件,以及发送日志到指定的email。

2)  logrotate的默认配置文件以及它的主要参数

logrotate 的配置文件是 /etc/logrotate.conf  主要参数如下表:

参数                                                    功能
compress                          通过gzip 压缩转储以后的日志
       nocompress                       不需要压缩时,用这个参数
       copytruncate                     用于还在打开中的日志文件,把当前日志备份并截断
       nocopytruncate                  备份日志文件但是不截断
       create mode owner group     转储文件,使用指定的文件模式创建新的日志文件
       nocreate                           不建立新的日志文件
       delaycompress 和 compress 一起使用时,转储的日志文件到下一次转储时才压缩

       nodelaycompress                 覆盖 delaycompress 选项,转储同时压缩。
       errors address                     专储时的错误信息发送到指定的Email 地址
       ifempty                              即使是空文件也转储,这个是 logrotate 的缺省选项。
       notifempty                          如果是空文件的话,不转储
       mail address                        把转储的日志文件发送到指定的E-mail 地址
       nomail                                转储时不发送日志文件
       olddir directory                 转储后的日志文件放入指定的目录,必须和当前日志文件在同一个文件系统
       noolddir                              转储后的日志文件和当前日志文件放在同一个目录下
       prerotate/endscript               在转储以前需要执行的命令可以放入这个对,这两个关键字必须单独成行
       postrotate/endscript             在转储以后需要执行的命令可以放入这个对,这两个关键字必须单独成行
       daily                                  指定转储周期为每天
       weekly                               指定转储周期为每周
       monthly                              指定转储周期为每月
       rotate count                        指定日志文件删除之前转储的次数,0 指没有备份,5 指保留5 个备份
       tabootext [+] list      让logrotate 不转储指定扩展名的文件,缺省的扩展名是:.rpm-orig, .rpmsave, v, 和 ~ 
       size size                  当日志文件到达指定的大小时才转储,Size 可以指定 bytes (缺省)以及KB (sizek)或者MB (sizem).

3)RedHad Linux的logrotate.conf解析

# see "man logrotate" for details
    # rotate log files weekly
    weekly
    # keep 4 weeks worth of backlogs
    rotate 4
# send errors to root
    errors root
    # create new (empty) log files after rotating old ones
    create
    # uncomment this if you want your log files compressed
    #compress
    1
# RPM packages drop log rotation information into this directory
    include /etc/logrotate.d
    # no packages own lastlog or wtmp --we'll rotate them here
    /var/log/wtmp {
    monthly
    create 0664 root utmp
    rotate 1
    }
/var/log/lastlog {
    monthly
    rotate 1
    }
# system-specific logs may be configured here

     使用include 选项读取其他配置文件
     include 选项允许系统管理员把分散到几个文件的转储信息,集中到一个主要的配置文件。当 logrotate 从logrotate.conf 读到include 选项时,会从指定文件读入配置信息,就好像他们已经在/etc/logrotate.conf 中一样。

     第13行 include /etc/logrotate.d 告诉 logrotate 读入存放在/etc/logrotate.d 目录中的日志转储参数,当系统中安装了RPM 软件包时,使用include 选项十分有用。RPM 软件包的日志转储参数一般存放在/etc/logrotate.d 目录。

     include 选项十分重要,一些应用把日志转储参数存放在 /etc/logrotate.d 。

     典型的应用有:apache, linuxconf, samba, cron 以及syslog。

     这样,系统管理员只要管理一个 /etc/logrotate.conf 文件就可以了。

     当 /etc/logrotate.conf 读入文件时,include 指定的文件中的转储参数将覆盖缺省的参数,如下例:

上面的信息放在文件logrotate中,它位于目录/etc/cron.daily中,由/etc/crontab配置起来由cron程序执行。

# linuxconf 的参数
/var/log/htmlaccess.log
   {
   errors jim
   notifempty
   nocompress
   weekly
   prerotate
/usr/bin/chattr -a /var/log/htmlaccess.log
   endscript
   postrotate
/usr/bin/chattr +a /var/log/htmlaccess.log
   endscript
   }
/var/log/netconf.log
   {
   nocompress
   monthly
   }

     在这个例子中,当 /etc/logrotate.d/linuxconf 文件被读入时,下面的参数将覆盖/etc/logrotate.conf中缺省的参数。

     Notifempty
     errors jim

4)logrotate 的执行

     logrotate 的运行分为三步:
     判断系统的日志文件,建立转储计划以及参数,通过cron daemon 运行

下面的代码是 Red Hat Linux 缺省的crontab 来每天运行logrotate。

#/etc/cron.daily/logrotate
#! /bin/sh
/usr/sbin/logrotate /etc/logrotate.conf

上面的信息保存在文件logrotate中,它其实是一个配置文件,位于/etc/cron.daily目录里。

/etc/cron.daily中的所有配置文件是每天都要由cron执行的程序的配置文件。它们都由系统管理员维护的/etc/crontab设置并执行。

 

发现asterisk的log日志/var/log/asterisk/full竟然有170M,所以寻找日志轮转的方式。按照如上的资料,只需要在修改/etc/logrotate.conf,增加

/var/log/asterisk/messages /var/log/asterisk/*log /var/log/asterisk/full {
   missingok
   rotate 5
   daily                                 

   create 0640 asterisk asterisk   
   postrotate
       /usr/sbin/asterisk -rx 'logger reload' > /dev/null 2> /dev/null
   endscript
}

reference :http://www.voip-info.org/tiki-index.php?page=logrotate

posted @ 2010-01-15 17:59  uu.Net  阅读(2597)  评论(0编辑  收藏  举报