我想将一些log.debug语句添加到我正在处理的类中,并且我希望在运行测试时在输出中看到它。我想在命令行上覆盖log4j属性,如下所示:
-Dlog4j.logger.com.mypackage.Thingie=DEBUG
我经常这样做。我特别感兴趣的是在命令行上传递它的方法。我知道如何使用配置文件来完成它,这不适合我的工作流程。
答案 0 :(得分:44)
作为jvm参数的一部分,您可以设置-Dlog4j.configuration=file:"<FILE_PATH>"
。其中FILE_PATH是log4j.properties文件的路径。
请注意,从log4j2开始,要使用的新系统变量是log4j.configurationFile
,并且您输入了文件的实际路径(即没有file:
前缀),它将会根据配置文件的扩展名自动加载工厂:
-Dlog4j.configurationFile=/path/to/log4jconfig.{ext}
答案 1 :(得分:25)
这些答案实际上阻止了我尝试最简单的事情!只需在log4j.configuration
中指定appender的阈值(例如&#34; console&#34;),就像这样:
log4j.appender.console.threshold=${my.logging.threshold}
然后,在命令行中包含系统属性-Dlog4j.info -Dmy.logging.threshold=INFO
。我假设任何其他属性都可以通过这种方式进行参数化,但这是提高或降低全局日志记录级别的最简单方法。
答案 2 :(得分:12)
log4j不直接支持此功能。
由于您不需要配置文件,因此很可能使用编程配置。我建议您研究扫描所有系统属性,并根据此显式编写您想要的内容。
答案 3 :(得分:10)
使用Log4j2,可以使用添加到代码中的以下实用程序方法来实现。
private static void setLogLevel() {
if (Boolean.getBoolean("log4j.debug")) {
Configurator.setLevel(System.getProperty("log4j.logger"), Level.DEBUG);
}
}
您需要这些导入
import org.apache.logging.log4j.Level;
import org.apache.logging.log4j.core.config.Configurator;
现在调用main()或适当的setLogLevel
方法并传递命令行参数-Dlog4j.logger=com.mypackage.Thingie
和-Dlog4j.debug=true
。
答案 4 :(得分:6)
基于ThorbjørnRavnAndersens的建议我写了一些使这项工作的代码
在main方法的早期添加以下内容,现在可以从命令行设置日志级别。这已在我的一个项目中测试过,但我是log4j的新手,可能会犯一些错误。如果是这样,请纠正我。
Logger.getRootLogger().setLevel(Level.WARN);
HashMap<String,Level> logLevels=new HashMap<String,Level>();
logLevels.put("ALL",Level.ALL);
logLevels.put("TRACE",Level.TRACE);
logLevels.put("DEBUG",Level.DEBUG);
logLevels.put("INFO",Level.INFO);
logLevels.put("WARN",Level.WARN);
logLevels.put("ERROR",Level.ERROR);
logLevels.put("FATAL",Level.FATAL);
logLevels.put("OFF",Level.OFF);
for(String name:System.getProperties().stringPropertyNames()){
String logger="log4j.logger.";
if(name.startsWith(logger)){
String loggerName=name.substring(logger.length());
String loggerValue=System.getProperty(name);
if(logLevels.containsKey(loggerValue))
Logger.getLogger(loggerName).setLevel(logLevels.get(loggerValue));
else
Logger.getRootLogger().warn("unknown log4j logg level on comand line: "+loggerValue);
}
}
答案 5 :(得分:2)
基于@lijat,这是一个简化的实现。在我的基于Spring的应用程序中,我只是将其作为bean加载。
public static void configureLog4jFromSystemProperties()
{
final String LOGGER_PREFIX = "log4j.logger.";
for(String propertyName : System.getProperties().stringPropertyNames())
{
if (propertyName.startsWith(LOGGER_PREFIX)) {
String loggerName = propertyName.substring(LOGGER_PREFIX.length());
String levelName = System.getProperty(propertyName, "");
Level level = Level.toLevel(levelName); // defaults to DEBUG
if (!"".equals(levelName) && !levelName.toUpperCase().equals(level.toString())) {
logger.error("Skipping unrecognized log4j log level " + levelName + ": -D" + propertyName + "=" + levelName);
continue;
}
logger.info("Setting " + loggerName + " => " + level.toString());
Logger.getLogger(loggerName).setLevel(level);
}
}
}
答案 6 :(得分:2)
在我的标准设置中,当以VM Option(在Java上课之前的命令行,或者在IDE中是VM Option)的方式传递时,我看到以下方法很好地工作:
-Droot.log.level=TRACE