pet*_*erp 12 java logging log4j
我在我的项目中使用以下代码来使用log4j记录调试消息
private static final Logger LOG = Logger.getLogger(MyClass.class)
// ...
if(LOG.isDebugEnabled()) {
LOG.debug("my log message");
}
Run Code Online (Sandbox Code Playgroud)
我可以通过在写入调试消息的行添加断点来确认我的log4j配置是否正确,即LOG.isDebugEnabled()返回true.有趣的是,我的调试消息并不在我的IDE(的IntelliJ)的控制台但是当改变显示,LOG.debug()到LOG.info()如预期将记录信息消息.
任何想法我应该寻找什么,以找出这里出了什么问题?
编辑:这是我的log4j.properties文件
log4j.appender.Stdout=org.apache.log4j.ConsoleAppender
log4j.appender.Stdout.layout=org.apache.log4j.PatternLayout
log4j.appender.Stdout.layout.conversionPattern=%-5p [%d{dd.MM.yy HH:mm:ss}] %C{1} - %m [thread: %t]\n
log4j.appender.Stdout.threshold=info
log4j.appender.StandaloneFile=org.apache.log4j.RollingFileAppender
log4j.appender.StandaloneFile.File=logs/standalone.log
log4j.appender.StandaloneFile.MaxFileSize=5MB
log4j.appender.StandaloneFile.MaxBackupIndex=20
log4j.appender.StandaloneFile.layout=org.apache.log4j.PatternLayout
log4j.appender.StandaloneFile.layout.ConversionPattern=%-5p [%d{dd.MM.yy HH:mm:ss}] %C{1} - %m [thread: %t]\n
log4j.appender.StandaloneFile.threshold=info
log4j.rootLogger=info, Stdout, StandaloneFile
log4j.logger.com.myPacke.package1=info, Stdout, StandaloneFile
log4j.logger.com.myPacke.package2=DEBUG
Run Code Online (Sandbox Code Playgroud)
log4j.appender.Stdout.threshold=info
Run Code Online (Sandbox Code Playgroud)
应该:
log4j.appender.Stdout.threshold=debug
Run Code Online (Sandbox Code Playgroud)
您只需将控制台阈值设置为info,这样您就无法获得调试级别日志.
请注意,您还将RollingFileAppender阈值设置为@Stephen C评论的信息.
| 归档时间: |
|
| 查看次数: |
31782 次 |
| 最近记录: |