Я пытаюсь использовать log4j2
с динамическим расположением каталога журнала. Я написал код для этого, как:log4j2 не работает для JAR
DateFormat dateFormat = new SimpleDateFormat(Constants.DATE_FORMAT);
Date date = new Date();
String currentDir = System.getProperty("user.dir") + "/" + Constants.OUTPUT_FOLDER_NAME + "/" + dateFormat.format(date);
System.setProperty("logDir", currentDir);
final LoggerContext ctx = (LoggerContext)LogManager.getContext(false);
ctx.reconfigure();
log4j2.xml выглядит следующим образом:
<?xml version="1.0" encoding="UTF-8"?>
<Configuration status="trace">
<Appenders>
<File name="file" fileName="${sys:logDir}/log.log">
<PatternLayout>
<Pattern>%d{ISO8601} [%t] %C %M - %p: %m%n</Pattern>
</PatternLayout>
</File>
<File name="report" fileName="${sys:logDir}/report.txt">
<PatternLayout>
<Pattern>%m%n</Pattern>
</PatternLayout>
</File>
<Console name="console" target="SYSTEM_OUT">
<PatternLayout>
<Pattern>%d{ISO8601} - %p: %m%n</Pattern>
</PatternLayout>
</Console>
</Appenders>
<Loggers>
<Logger name="Report" level="info" additivity="false">
<AppenderRef ref="report" level="INFO"/>
</Logger>
<Root level="info">
<AppenderRef ref="file" level="INFO" />
<AppenderRef ref="console" level="INFO" />
</Root>
</Loggers>
</Configuration>
файлы генерируются хорошо, когда я запускаю это в Eclipse, но когда я запускаю основной класс моей программы используя файл JAR, содержащий скомпилированный основной класс по классам, как:
java -cp CLASSPATH -Dlog4j.configuration=file:XMLFILE ClassName args
печатает только «ошибка» сообщения на консоль. Структура каталогов и файлы также не создаются. Что я делаю не так?
Спасибо!
спасибо! Я не включал каталог XML-файла в путь к классам. –