Cronolog 介绍

阅读更多
在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 介绍)