修改log4j配置文件来减小Linux系统tomcat/logs目录下的catalina.out文件的大小

时间:2022-11-12 12:18:48

    近两天linux下的tomcat/logs目录下catalina.out文件过大(基本上是每三个月就达到4G),除了网上找到的使用cronolog工具进行对此日志进行分割之外。也可以通过配置服务的log4j.properties文件进行屏蔽(估计这个是跟我的服务有关系,因为我的MSA服务里面打印了很多日志信息,具体log4j配置见下面)。因为我发现catalina.out文件里记录的日志都是在MyEclipse里面控制台上打印的信息所以只要修改log4j.properties文件就可以了。

(如果是从MyEclipse里面启动的话,tomcat/logs目录下是不会产生如下日志记录的,只有从tomcat/bin目录下执行startup.bat命令才会有下列日志输出。这个原因为什么暂时还不清楚。)

修改log4j配置文件来减小Linux系统tomcat/logs目录下的catalina.out文件的大小

我原先的log4j.properties配置文件如下。这样的话就把日志信息打印到控制台了,catalina.out里面也就记录了相应的日志记录。如果去掉红色字体部分。那么msa.log文件还是会记录日志。但是catalina.out就不会再记录日志信息了,相应的如果是在MyEclipse里面控制台也不会打印日志语句了,如果是startup.bat启动命令行窗口也不会打印日志了,这种情况也可以解决catalina.out过大的问题。

<span style="font-size:18px;">log4j.rootLogger=OFF,<span style="color:#ff0000;">stdout</span>
log4j.logger.org.springframework = ERROR,logfile
log4j.logger.org.apache.struts = ERROR,logfile
log4j.logger.msa=debug,logfile

<span style="color:#ff0000;">log4j.appender.stdout=org.apache.log4j.ConsoleAppender
log4j.appender.stdout.layout=org.apache.log4j.PatternLayout
log4j.appender.stdout.layout.ConversionPattern=[%d{yyyy-MM-dd HH:mm:ss}]%-5p %l [%t] %m%n</span>

log4j.appender.logfile=org.apache.log4j.RollingFileAppender
log4j.appender.logfile.File=${msa.root}/../../logs/msa.log
log4j.appender.logfile.MaxFileSize=4096KB
#Keep three backup files.
log4j.appender.logfile.MaxBackupIndex=10
# Pattern to output: date priority [category] - message
log4j.appender.logfile.layout=org.apache.log4j.PatternLayout
log4j.appender.logfile.layout.ConversionPattern=[%d{yyyy-MM-dd HH\:mm\:ss}]%-5p %l [%t] %m%n</span>