【发布时间】:2015-12-17 19:10:43
【问题描述】:
我正在尝试将进程日志保存到文件中。当我在 netbeans 中运行该类时,这工作正常,但在我导出 JAR 文件后,进程无法选择 logback.xml。
jar 文件与 logback.xml 位于同一路径。我已经尝试使用在这里找到的所有示例:
使用命令行文件:
java -Dlogback.configurationFile=logback.xml test.jar
设置类路径:
java =cp "./" -jar test.jar
这是配置文件:
<?xml version="1.0" encoding="UTF-8"?>
<configuration>
<appender name="STDOUT" class="ch.qos.logback.core.ConsoleAppender">
<encoder class="ch.qos.logback.classic.encoder.PatternLayoutEncoder">
<!--<Pattern>%d{HH:mm:ss.SSS} [%thread] %-5level %logger{36} %M:%L- %msg%n</Pattern> -->
<Pattern>%d{HH:mm:ss.SSS} %-5level %logger{36} %M:%L - %msg%n
</Pattern>
<!--<Pattern>%d{dd/MM/yyyy HH:mm:ss.SSS} [%thread] %-5level %C{0}:%L -
%msg%n</Pattern> -->
</encoder>
</appender>
<appender name="FILE"
class="ch.qos.logback.core.rolling.RollingFileAppender">
<file>test.log</file>
<rollingPolicy class="ch.qos.logback.core.rolling.TimeBasedRollingPolicy">
<!-- daily rollover -->
<fileNamePattern>test.%d{yyyy-MM-dd}.log</fileNamePattern>
<!-- keep 30 days' worth of history -->
<maxHistory>30</maxHistory>
</rollingPolicy>
<encoder>
<!--<pattern>%-4relative [%thread] %-5level %logger{35} - %msg%n</pattern> -->
<pattern>%d{dd/MM/yyyy HH:mm:ss.SSS} [%thread] %-5level %C{0}:%L -
%msg%n</pattern>
</encoder>
</appender>
<root level="DEBUG">
<appender-ref ref="FILE" />
<appender-ref ref="STDOUT" />
</root>
</configuration>
请帮忙!谢谢
【问题讨论】:
-
为什么配置文件不在jar里面?
-
我不知道。应该在吗?无论如何..我尝试在 JAR 文件中添加 xml,但它一直使用默认配置,
-
您似乎遗漏了配置中的
<configuration>标签,还是您将它们遗漏了? -
我在复制/粘贴时出错了。但就像我说的,这适用于 Netbeans。但是如果我使用jar,例如eclipse,总是使用默认配置。文件在哪里并不重要。
-
好吧,它在类路径中寻找
logback.xml。这很简单。