7

我有一个 log4j 记录器,它当前将日志同时写入控制台和文件,效果很好。

稍后我想将其配置为将 INFO + ERROR 记录到日志文件中,但仅在控制台上显示 ERROR。我必须改变什么才能实现这一目标?

log4j.rootLogger=INFO, console, MyFileAppender

log4j.logger.org.apache.cxf=INFO, console
log4j.logger.org.apache.cxf.interceptor.LoggingInInterceptor=INFO, console
log4j.logger.org.apache.cxf.interceptor.LoggingOutInterceptor=INFO, console

log4j.appender.console=org.apache.log4j.ConsoleAppender
log4j.appender.console.Target=System.out

log4j.appender.MyFileAppender=org.apache.log4j.RollingFileAppender
log4j.appender.MyFileAppender.Append=true
log4j.appender.MyFileAppender.File=c:/logs.log

此外,我想阻止将 CXF XML 请求记录在文件中。但我希望它们仍然显示在控制台中。如何?

4

2 回答 2

10

基于 Appender 的配置

必须单独配置每个附加程序的日志级别,除非它与根级别配置相同。下面的示例log4.properties文件被配置为将日志INFO及以上记录到控制台中,但仅ERROR将以上记录到文件中。

log4j.appender.[appender-name].Threshold=[Level]

查看以下示例的最后一行(来自“如何将 log4j 与您的 Java 项目集成”)。

# root level configurations 
log4j.rootLogger=INFO,console,file   

# configuration for console outputs  
log4j.appender.console=org.apache.log4j.ConsoleAppender  
log4j.appender.console.layout=org.apache.log4j.PatternLayout  

# configuration for file output (into a file named messages.log)  
log4j.appender.file=org.apache.log4j.RollingFileAppender  
log4j.appender.file.File=messages.log  
log4j.appender.file.layout=org.apache.log4j.PatternLayout 

# threshold for file output 
log4j.appender.file.Threshold=ERROR

基于包的日志级别

以下任何一项都会有所帮助。

log4j.logger.[package]=[Level]
log4j.logger.[package]=[Level], [Appender]

举个例子:

log4j.logger.org.apache.cxf=INFO, console
于 2013-11-05T18:15:38.770 回答
4

根据这个 SO question(及其答案),您必须在 appenders 上设置一个阈值:

log4j.appender.console=org.apache.log4j.ConsoleAppender
log4j.appender.console.Target=System.out
log4j.appender.console.Threshold=ERROR

log4j.appender.MyFileAppender=org.apache.log4j.RollingFileAppender
log4j.appender.MyFileAppender.Append=true
log4j.appender.MyFileAppender.File=c:/logs.log
log4j.appender.MyFileAppender.Threshold=INFO
于 2013-11-05T12:24:09.603 回答