Linux 日志超大问题
为了能够满足我的一个项目中日志输出的特殊要求,我花了好几个小时配置log4j 为Tomcat5.0.28 输出日志。本文说明了一些机制,并且描述了配置Tomcat 每日生成一个日志文件的步骤,涵盖Tomcat5.0.x 和5.5.x 版本。 注 : 最新的 log4j 1.3 alpha 测试版已经支持每日生成一个日志文件。参考本文 相关链接 了解如何进行安装和配置。
Tomcat 5.0 .x 的日志
Tomcat 5.0.x 主要由两个途径记录日志信息。分别为标准日志输出文件catalina.out 和一般情况下在文件名中包含有日期的 Servlet 日志文件(如:catalina.2004-08-27.log ) 。
catalina.out 中的数据主要有三个来源:输出至标准输入和标准错误输出的数据, 通过Commons Logging 接口输出的日志信息,还有一种是包括了Tomcat 各种事件状态和其它系统(如Jakarta Struts )的输出。使用Commons Logging 接口可以根据配置输出多种多样的日志数据形式。
The data in the Servlet 的日志数据是调用ServletContext 类的log() 方法产生的,例如:
httpServletRequest.getSession().getServletContext().log(\"Some message\");要保存输出信息到日志文件,你需要在 Tomcat 的配置文件( Tomcat 的 conf 目录下) server.xml 中对 FileLogger 配置,一般如下:
prefix=\"servlet.\" suffix=\".log\" timestamp=\"true\" />
Servlet 日志可以打开(配置了 FileLogger )和关闭(没有配置 FileLogger ),但是没有办法指定日志输出级别(只能输出 INFO 以及更高级别的日志信息)。尽管 Tomcat 的文档中提到它所有的 Logger 都支持 verbosity 配置项,但是好像没有什么效果。
如果希望配置Tomcat 捕获所有的日志数据,输出到每日生成一个的日志文件(如:在文件名中表明产生日期)。Tomcat 中FileLogger 提供一种标准方法用于捕获Servlet 日志流并每天生成一个新的文件。你可以对日志文件进行备份、删除、分析或者你希望的其它操作。
如果Tomcat 再有一个使用Commons Logging 接口的Catalina Logger 就好了,可以让你更好的控制输出的格式,虽然这个模块很相当容易实现的,但是谁有时间来做啊。后面会告诉大家如何控制 catalina.out 。
Tomcat 5.5 .x 的日志
Tomcat 5.5.x 有两条途径记录日志数据,写入标准输出和标准错误输出的所有内容还是记录在文件catalina.out ,其余的所有日志都通过 Commons Logging 接口输出。如果你没有配置用来其它的Logger (如log4j ),所有的日志信息(包括通过commons-logging 输出的所有内容)都会输出到catalina.out ,致使其不断增长。
Tomcat 5.5.x 比Tomcat 5.0.x 的一项改进是Servlet 日志不在存在了,Servlet 日志是用来接收任何传递给ServletContext 类的log() 方法的内容,例如:
httpServletRequest.getSession().getServletContext().log(\"Some message\");Tomcat 5.5.x 现在将这些信息通过commons-logging 接口输出为INFO 级别的日志。如果配置了像log4j 这样的logger ,你可以把所有的日志信息输入到每日生成的日志文件(如:在文件名中表明产生日期)中,你可以对日志文件进行备份、删除、分析或者你希望的其它操作。
Tomcat 通用日志
如上所述,在catalina.out 文件中的大部分数据都是通过调用Commons Logging 接口产生的,Commons Logging 可以让你在运行期对日志输出细节进行控制,并允许使用多种后台日志系统,Tomcat 标准发行版使用SimpleLog 作为日志系统,SimpleLog 将所有的内容都输出到标准错误输出,对于Tomcat 来说,默认被重定向到catalina.out 文件,这样就造成 catalina.out 文件不停的增长,不生成循环的日志文件。
Log4j
Log4j 是支持Commons Logging 的强大日志系统,可以添加到你的Tomcat 中替换SimpleLog 以支持循环的日志文件和多样化的配置。事实上,你不但可以将日志输出到文件,也可以输出到操作系统日志,或者远程机器等其它的目标,你还可以输出至不止一个地方。要在你的Tomcat 中使用log4j 系统可以按照如下步骤进行安装配置(注:这是针对log4j 1.2.x 版本,1.3.x alpha 测试版本的安装和配置可以参考附录中的相关链接 ):
如果 Tomcat 当前正在运行,关闭 Tomcat 。 从 Apache 的网站 下载 Commons Logging 发行包。 将压缩包中的 commons-logging.jar 解压缩到你Tomcat 安装路径的common/lib 目录中。 从 Apache 的网站 下载 Log4j 发行包。 将压缩包中的 log4j-1.2.12.jar 解压缩到你Tomcat 安装路径的common/lib 目录中。 在 Tomcat 安装路径的 common/classes 创建 log4j 的配置文件 log4j.properties (配置文件在随后一节)。 重起 Tomcat
这里描述的配置会导致在 Tomcat 5.5.x 中创建两个日志文件,在 Tomat 5.0.x 中创建三个文件:一个是 Servlet 日志文件(仅对 Tomcat 5.0.x ),在每天晚上循环产生新的日志文件;第二个是通过 log4j 输出的 Commons Logging 日志文件(也会在每天晚上循环产生新的日志文件),还有一个是仅仅包含了打印到标准输出和标准错误输出的 catalina.out 文件,这个文件仍然会不断的增长,但是如果你的 Tomcat 应用程序设计的比较好,不是使用标准输出和标准错误输出,这就不成问题了(其实,这个文件应该大小为 0 )。
注意,commons-logging.jar 和log4j.jar files 是安装在Tomcat 的common/lib 目录中,而log4j.properties 文件是安装在common/classes 目录中。这样的配置可以让Tomcat 和你的Web 应用程序都能够使用log4j 。如果你的Web 应用程序使用Commons Logging 接口,那么其日志数据将会输出到Tomcat 服务的日志中。你也可以修改log4j 的配置文件log4j.properties ,将你的应用程序日志输出到其它文件中(配置方法请参考log4j 的其它文档)。
Log4j 配置文件
log4j.properties 文件可以如下配置:
## Configures Log4j as the Tomcat system logger# to output info level messages into a rolling log file.#log4j.rootLogger=INFO, R## To continue using the \"catalina.out\" file (which grows forever),# comment out the above line and uncomment the next.##log4j.rootLogger=ERROR, A1 ## Configuration for standard output (\"catalina.out\").#log4j.appender.A1=org.apache.log4j.ConsoleAppenderlog4j.appender.A1.layout=org.apache.log4j.PatternLayout ## Print the date in ISO 8601 format#log4j.appender.A1.layout.ConversionPattern=%d %-5p %c - %m%n
## Configuration for a rolling log file (\"tomcat.log\").#log4j.appender.R=org.apache.log4j.DailyRollingFileAppenderlog4j.appender.R.DatePattern='.'yyyy-MM-dd## Edit the next line to point to your