Chinaunix首页 | 论坛 | 博客
  • 博客访问: 1724652
  • 博文数量: 293
  • 博客积分: 10574
  • 博客等级: 上将
  • 技术积分: 5085
  • 用 户 组: 普通用户
  • 注册时间: 2006-12-22 17:00
文章分类

全部博文(293)

文章存档

2011年(27)

2010年(84)

2009年(62)

2008年(120)

我的朋友

分类: LINUX

2010-12-08 09:47:17

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

Cronolog是一个小巧高效的日志文件处理工具,可以实现自动的按规则生成周期性的日志文件。我们以对Apache access log和Tomcat运行日志的处理为例进行说明。


一.安装

1. 到下载(目前最新为1.62)的源码包,并解压到某目录;

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 按照分钟批次生成日志

CustomLog "|/usr/sbin/cronolog --period=10minutes aaa_`/httpd/bin/hostname -s`_%Y_%m_%d_%H_%M.log" aaaaaaa

阅读(699) | 评论(0) | 转发(0) |
给主人留下些什么吧!~~