我已经把log4j放到了我的buildpath中,但是当我运行我的应用程序时,我得到了以下消息:
log4j:WARN No appenders could be found for logger (dao.hsqlmanager).
log4j:WARN Please initialize the log4j system properly.
log4j:WARN See http://logging.apache.org/log4j/1.2/faq.html#noconfig for more info.
这些警告是什么意思?这里的阑尾是什么?
当Log4J Java代码在程序中搜索以创建第一行日志时,Log4J将显示此警告消息。
此时Log4j做了两件事
它搜索log4j。属性文件
它搜索实例化log4j.properties中定义的appender
如果log4J没有找到log4J。属性文件或在log4j中声明的appender。在log4j的其他地方没有定义Rootlogger。系统弹出“属性”文件中的警告信息。
注意:“属性”文件内容必须正确。
以下内容不正确
log4j.rootLogger=file
log4j.appender.FILE=org.apache.log4j.FileAppender
log4j.appender.FILE.File=c:/Trace/MsgStackLogging.log
log4j.appender.FILE.layout=org.apache.log4j.PatternLayout
log4j.appender.FILE.layout.ConversionPattern=%m%n
log4j.appender.FILE.ImmediateFlush=true
log4j.appender.FILE.Threshold=debug
log4j.appender.FILE.Append=false
因为文件appender在log4j中是以小写形式声明的。并在log4j中定义。使用大写!
正确的文件应该是
log4j.rootLogger=FILE
log4j.appender.FILE=org.apache.log4j.FileAppender
log4j.appender.FILE.File=c:/Trace/MsgStackLogging.log
log4j.appender.FILE.layout=org.apache.log4j.PatternLayout
log4j.appender.FILE.layout.ConversionPattern=%m%n
log4j.appender.FILE.ImmediateFlush=true
log4j.appender.FILE.Threshold=debug
log4j.appender.FILE.Append=false
如果使用MAVEN,则必须放置log4j。src/main/resources中的properties文件并启动MAVEN构建。
Log4j。然后将属性文件复制到目标/类文件夹中。
Log4J使用Log4J。属性文件,它发现在目标/类!
我在使用log4j2时也遇到了同样的问题。我的问题是由使用错误的依赖库引起的:
<dependency>
<groupId>org.slf4j</groupId>
<artifactId>slf4j-log4j12</artifactId>
<scope>runtime</scope>
</dependency>
相反,我应该使用:
<dependency>
<groupId>org.apache.logging.log4j</groupId>
<artifactId>log4j-slf4j-impl</artifactId>
<scope>runtime</scope>
</dependency>
在我的情况下,我有一个log4j2.xml定义在我的“资源”目录,并指定使用它:
System.setProperty("log4j.configurationFile", "log4j2.xml");
这里的大多数答案都建议使用log4j。属性文件放置在正确的位置(对于maven项目,它应该位于src/main/resources)
但对我来说,问题是log4j。属性配置不正确。这是一个适合我的样品,你可以先试用一下。
# Root logger option
log4j.rootLogger=INFO, stdout
# Direct log messages to stdout
log4j.appender.stdout=org.apache.log4j.ConsoleAppender
log4j.appender.stdout.Target=System.out
log4j.appender.stdout.layout=org.apache.log4j.PatternLayout
log4j.appender.stdout.layout.ConversionPattern=%d{yyyy-MM-dd HH:mm:ss} %-5p %c{1}:%L - %m%n
考虑log4j JVM参数Dlog4j.configuration
一般来说:
添加指向log4j配置文件的JVM参数。
语法如下:
java [ options ] -jar file.jar [ arguments ]
一个真实的命令行示例如下所示:
java -Dlog4j.configuration=conf/log4j.xml -jar myJarFile.jar myArg1 myArg2
对于IntelliJ IDE用户:
1.Run/Debug Configurations
2.Edit configurations...
3.VM options
4.Enter the same value also starting with "-D"
小贴士:
1.Eclipse IDE用户将找到等效的方法
2.对于运行/调试配置编辑器,很可能在开始时,您的特定可执行文件不存在。根据您当前正在处理的项目的大小,在目录中找到它可能会令人不快。如果在继续运行/调试配置之前只运行/执行一次文件(单击play),无论执行结果是什么,都不会太麻烦。
3.请注意您的工作目录、相对路径和类路径。