Cronolog 介绍

转自:http://blog.cnr.cn/18/viewspace-7680.html

在Unix的Daemon程序中,利用日志文件来进行记录使用信息或者错误信息是最常用的手段。除了系统本身的syslog可以实现自动的rotation以外,大部分时候的log并不会实现自动的轮换,这样往往导致一个很大的日志文件,在进行查找、历史记录处理和统计等时候带来很多的不方便之住。

 
Cronolog是一个小巧高效的日志文件处理工具,可以实现自动的按规则生成周期性的日志文件。我们以对Apache access log和Tomcat运行日志的处理为例进行说明。
 
一.安装
 1.      到
www.cronolog.org 下载的源码包,并解压到某目录;
 2.      su - root;cd /path/to/cronolog;./configure;make; make install――会将cronolog安装到/usr/local/sbin;同时安装相应的man pages。 建议strip /usr/local/sbin/cronolog以进一步减小其文件大小(大概20多k)。
 
二.基本使用方式
 cronolog一般是采取管道的方式来工作的,采用如下的形式:
 # loggenerator | cronolog log_file_pattern
 其中,loggenerator为产生log的程序,而log_file_pattern是日志文件的路径,可以在其中加入cronolog所支持的时间相关的pattern字符,如/www/log/%y/%m/%d/access.log。其patter为%字符后跟一特殊字符,简述如下:
 转义符:
 %    %字符
 n    换行
 t    水平制表符
 时间域:
 H    小时(00..23)
 I    小时(01..12)
 p    该locale下的AM或PM标识
 M    分钟(00..59)
 S    秒 (00..61, which allows for leap seconds)
 X    该locale下时间表示符(e.g.: "15:12:47")
 Z    时区。若时区不能确定,则无意义
 日期域:
 a    该locale下的工作日简名(e.g.: Sun..Sat)
 A    该locale下的工作日全名(e.g.: Sunday ..  Satur-ay)
 b    该locale下的月份简称(e.g.: Jan .. Dec)
 B    该locale下的月份全称(e.g.:  January .. December)
 c    该locale下的日期和时间(e.g.: "Sun Dec 15  14:12:47 GMT 1996")
 d    当月中的天数 (01 .. 31)
 j    当年中的天数 (001 .. 366)
 m    月数 (01 .. 12)
 U    当年中的星期数,以周日作为一周开始,其中第一周为首个含星期天的星期(00..53)
 W    当年中的星期数,以星期一作为一周的开始,其中第一周为首个含星期天的星期(00..53)
 w    工作日数(0 .. 6, 0表示星期天)
 x    该locale下的日期表示(e.g. "13/04/97")
 y    两位数的年份(00 .. 99)
 Y    四位数的年份(1970 .. 2038)
 
三.Apache日志的使用方式
 编辑httpd.conf文件,将其中的
 CustomLog /usr/local/apache/logs/access_log combined这行,改为:
 CustomLog "|/usr/local/sbin/cronolog /usr/local/apache/logs/%Y_week_%U/access_log" combined
   注意其中的双引号是必须的,因为这是一个管道操作。上述的配置将在apache的logs目录下,建立形如2002_week_50等按周方式编排的目录,然后将apache的access log写入到access_log文件,格式为combined。  Cronolog将自动完成目录生成,在周期边界点上准时切换等操作。
 
四.Tomcat日志的使用方式
 目前大部分系统的Tomcat在启动的时候,大部分是以xxx或者portal等非root用户,用nohup command_line &的方式来启动的,tomcat的debug等输出信息将自动追写入tomcat当前目录下的nohup.out文件。时间长了该文件将变得非常大,给处理和清楚带来麻烦。采用cronolog的方式如下:
 在用户home下建立runlog的目录,用于存放tomcat运行日志;
 将启动脚本或者监控脚本中的如下命令:
 cd $HOME/tomcat3/bin;
 nohup ./startup.sh
 改成:
 cd $HOME/tomcat3/bin
 nohup ./startup.sh 2>&1 | /usr/local/sbin/cronolog /path/to/runlog/tomcat-%Y%m%d.log &
 这样即可在对应的runlog目录下,每天生成一个tomcat的运行日志,为以后的检查和排错带来莫大的好处!
 

可以这样说,只要是有log的地方,cronolog总可以发挥它的作用――希望能为我们的工作带来好处

你可能感兴趣的:(Cronolog 介绍)