关闭tomcat的stdout日志,并将System.out.println的内容输出到指定文件

环境是tomcat7

生产环境中的tomcat/logs下的xxx日期.stdout文件并不是按照日期每天生成一个,导致此文件越来越大。需要将其屏蔽掉,但是老程序中还存在着大量System.out.println,有些时候需要看这些输出查找问题,所以这里将tomcat默认的logging换成log4j。

1.参考http://tomcat.apache.org/tomcat-7.0-doc/logging.html的Using Log4j章节将日志记录换成log4j

默认的log4j.properties文件中的catalina的文件是按照天打印的,一天的日志量还是太大,将其改成按照大小打印,超过设定大小生成新文件

log4j.appender.CATALINA = org.apache.log4j.RollingFileAppender
log4j.appender.CATALINA.File = ${catalina.base}/logs/catalina
log4j.appender.CATALINA.Append = true
log4j.appender.CATALINA.Encoding = UTF-8
log4j.appender.CATALINA.layout = org.apache.log4j.PatternLayout
log4j.appender.CATALINA.layout.ConversionPattern = %d [%t] %-5p %c- %m%n
log4j.appender.CATALINA.maxFileSize = 10KB
log4j.appender.CATALINA.maxBackupIndex = 10
maxFileSize是文件的大小 

maxBackupIndex是保留最多几个文件

2.修改tomcat/conf/context.xml在context节点上加上swallowOutput="true"

3.修改tomcat/bin/service.bat

set PR_STDOUTPUT=auto
set PR_STDERROR=auto

删掉auto,重新注册系统服务

你可能感兴趣的:(关闭tomcat的stdout日志,并将System.out.println的内容输出到指定文件)