在添加log4j到我的应用程序后,每次执行我的应用程序时,我都会得到以下输出:
log4j:WARN No appenders could be found for logger (slideselector.facedata.FaceDataParser).
log4j:WARN Please initialize the log4j system properly.
这似乎意味着一个配置文件丢失了。
这个配置文件应该放在哪里,一个好的开始内容是什么?
我正在使用纯java开发桌面应用程序。所以没有网络服务器等等…
默认情况下,Log4j查找一个名为Log4j的文件。属性或类路径上的log4j.xml。
您可以通过设置这里描述的系统属性来控制它使用哪个文件来初始化自己(请参阅“默认初始化过程”部分)。
例如:
java -Dlog4j.configuration=customName ....
将导致log4j在类路径上查找名为customName的文件。
如果你有问题,我发现打开log4j.debug很有帮助:
-Dlog4j.debug
它将打印到系统。给出了很多有用的信息,比如它使用哪个文件来初始化自己,哪个记录器/追加器被配置了,以及如何配置等等。
配置文件可以是java属性文件,也可以是xml文件。下面是来自log4j介绍文档页面的属性文件格式示例:
log4j.rootLogger=debug, stdout, R
log4j.appender.stdout=org.apache.log4j.ConsoleAppender
log4j.appender.stdout.layout=org.apache.log4j.PatternLayout
# Pattern to output the caller's file name and line number.
log4j.appender.stdout.layout.ConversionPattern=%5p [%t] (%F:%L) - %m%n
log4j.appender.R=org.apache.log4j.RollingFileAppender
log4j.appender.R.File=example.log
log4j.appender.R.MaxFileSize=100KB
# Keep one backup file
log4j.appender.R.MaxBackupIndex=1
log4j.appender.R.layout=org.apache.log4j.PatternLayout
log4j.appender.R.layout.ConversionPattern=%p %t %c - %m%n
默认情况下,Log4j查找一个名为Log4j的文件。属性或类路径上的log4j.xml。
您可以通过设置这里描述的系统属性来控制它使用哪个文件来初始化自己(请参阅“默认初始化过程”部分)。
例如:
java -Dlog4j.configuration=customName ....
将导致log4j在类路径上查找名为customName的文件。
如果你有问题,我发现打开log4j.debug很有帮助:
-Dlog4j.debug
它将打印到系统。给出了很多有用的信息,比如它使用哪个文件来初始化自己,哪个记录器/追加器被配置了,以及如何配置等等。
配置文件可以是java属性文件,也可以是xml文件。下面是来自log4j介绍文档页面的属性文件格式示例:
log4j.rootLogger=debug, stdout, R
log4j.appender.stdout=org.apache.log4j.ConsoleAppender
log4j.appender.stdout.layout=org.apache.log4j.PatternLayout
# Pattern to output the caller's file name and line number.
log4j.appender.stdout.layout.ConversionPattern=%5p [%t] (%F:%L) - %m%n
log4j.appender.R=org.apache.log4j.RollingFileAppender
log4j.appender.R.File=example.log
log4j.appender.R.MaxFileSize=100KB
# Keep one backup file
log4j.appender.R.MaxBackupIndex=1
log4j.appender.R.layout=org.apache.log4j.PatternLayout
log4j.appender.R.layout.ConversionPattern=%p %t %c - %m%n
另一种不将属性文件放在类路径上的方法是直接从java代码中设置属性。下面是示例代码。
public class Log4JSample {
public static void main(String[] args) {
Properties properties=new Properties();
properties.setProperty("log4j.rootLogger","TRACE,stdout,MyFile");
properties.setProperty("log4j.rootCategory","TRACE");
properties.setProperty("log4j.appender.stdout", "org.apache.log4j.ConsoleAppender");
properties.setProperty("log4j.appender.stdout.layout", "org.apache.log4j.PatternLayout");
properties.setProperty("log4j.appender.stdout.layout.ConversionPattern","%d{yyyy/MM/dd HH:mm:ss.SSS} [%5p] %t (%F) - %m%n");
properties.setProperty("log4j.appender.MyFile", "org.apache.log4j.RollingFileAppender");
properties.setProperty("log4j.appender.MyFile.File", "my_example.log");
properties.setProperty("log4j.appender.MyFile.MaxFileSize", "100KB");
properties.setProperty("log4j.appender.MyFile.MaxBackupIndex", "1");
properties.setProperty("log4j.appender.MyFile.layout", "org.apache.log4j.PatternLayout");
properties.setProperty("log4j.appender.MyFile.layout.ConversionPattern","%d{yyyy/MM/dd HH:mm:ss.SSS} [%5p] %t (%F) - %m%n");
PropertyConfigurator.configure(properties);
Logger logger = Logger.getLogger("MyFile");
logger.fatal("This is a FATAL message.");
logger.error("This is an ERROR message.");
logger.warn("This is a WARN message.");
logger.info("This is an INFO message.");
logger.debug("This is a DEBUG message.");
logger.trace("This is a TRACE message.");
}
}
如前所述,有两种方法
首先是将这一行添加到你的main方法中:
BasicConfigurator.configure();
第二种方法是添加这个标准log4j。属性文件到你的类路径:
在采用第二种方法时,您需要确保正确地初始化了文件。
Eg.
Properties props = new Properties();
props.load(new FileInputStream("log4j property file path"));
props.setProperty("log4j.appender.File.File", "Folder where you want to store log files/" + "File Name");
确保创建了存储日志文件所需的文件夹。