12

我正在尝试通过 commons-logging 使用 log4j,如果 log4j 属性文件不称为 log4.properties,则会出现问题。我收到以下错误:log4j:WARN No appenders could be found for logger (LogMePlease)。log4j:WARN 请正确初始化 log4j 系统。

我的代码很简单:

import org.apache.commons.logging.Log;
import org.apache.commons.logging.LogFactory;

public class LogMePlease 
{
static Log l = LogFactory.getLog(LogMePlease.class);

public static void main(String [] args)
{
    l.warn("Hello World!");
}
}

在我的类路径中,我有: commons-logging.properties文件,其中包含以下条目

org.apache.commons.logging.Log=org.apache.commons.logging.impl.Log4JLogger
log4j.configuration=log4j-test.properties

log4j-test.properties文件

当我运行这段代码时,我得到

log4j:WARN No appenders could be found for logger (LogMePlease).
log4j:WARN Please initialize the log4j system properly.

如果我将 log4j-test.properties 文件重命名为 log4j.properties - 那么一切正常。所以,问题是如何设置公共日志记录以使用 log4j.properties 文件的任意名称。

4

3 回答 3

11

该文件commons-logging.properties仅从公共日志中读取,而 log4j 将log4j.configuration在系统属性中查找。

因此,您必须-Dlog4j.configuration=log4j-test.properties在命令行上将它们指定为 JVM 选项,或者必须System.setProperty()在第一次调用任何日志记录方法之前调用(这通常很难实现)。

注意:如果可以,请使用 XML 配置log4j.xml;配置 log4j 更加简单和强大。

于 2009-10-06T07:48:22.923 回答
1

您需要将协议添加到系统属性值的前面,如下所示:-Dlog4j.configuration=file://log4j-test.properties

如果没有协议,它将在类路径中查找。

于 2013-10-10T18:20:00.870 回答
0

jul-commons-logging,它喜欢你的情况。

org.apache.commons.logging.LogFactory=org.apache.commons.logging.impl.LogFactoryImpl
#org.apache.commons.logging.Log=org.apache.commons.logging.impl.Jdk14Logger
#org.apache.commons.logging.Log=org.apache.commons.logging.impl.SimpleLog
org.apache.commons.logging.Log=org.apache.commons.logging.impl.Log4JLogger

在 Log 实例之前设置 log4j.properties。

System.setProperty("log4j.configuration", "log4j.properties");
于 2014-07-31T09:08:28.587 回答