gpt4 book ai didi

maven - 使用 maven-jetty-plugin 进行 logback 日志记录

转载 作者:行者123 更新时间:2023-12-04 05:56:44 25 4
gpt4 key购买 nike

我想在 maven-jetty-plugin 中使用 logback 日志记录。显然,系统属性 logback.configurationFile 被读取 maven-jetty-plugin 已启动并已初始化 slf4j,因此文件 ./src/test/resources/logback.xml 不会被 jetty 读取。
结果,我将所有日志消息设置为调试级别并打印到控制台(默认的 logback 配置)。使用 -Dlogback.configurationFile=... 启动 maven 解决了这个问题。但是,我更喜欢在 pom 中设置属性,因为可以使用 log4j 和 maven-jetty-plugin。有任何想法吗 ?

这是我的 pom.xml:

...
<plugin>
<groupId>org.mortbay.jetty</groupId>
<artifactId>jetty-maven-plugin</artifactId>
<version>8.0.4.v20111024</version>
<dependencies>
<dependency>
<groupId>ch.qos.logback</groupId>
<artifactId>logback-classic</artifactId>
<version>1.0.0</version>
</dependency>
<dependency>
<groupId>org.slf4j</groupId>
<artifactId>slf4j-api</artifactId>
<version>1.6.1</version>
</dependency>
</dependencies>
<configuration>
<systemProperties>
<systemProperty>
<name>logback.configurationFile</name>
<value>./src/test/resources/logback.xml</value>
</systemProperty>
</systemProperties>
...

这是 logback.xml:
<configuration>

<appender name="FILE" class="ch.qos.logback.core.rolling.RollingFileAppender">
<file>logFile.log</file>
<rollingPolicy class="ch.qos.logback.core.rolling.TimeBasedRollingPolicy">
<!-- daily rollover -->
<fileNamePattern>logFile.%d{yyyy-MM-dd}.log</fileNamePattern>
</rollingPolicy>

<encoder>
<pattern>%-4relative [%thread] %-5level %logger{35} - %msg%n</pattern>
</encoder>

</appender>

<root level="INFO">
<appender-ref ref="FILE" />
</root>

</configuration>

最佳答案

使用旧版 maven-jetty-plugin而不是 jetty-maven-plugin对我有用:

<plugin>
<groupId>org.mortbay.jetty</groupId>
<artifactId>maven-jetty-plugin</artifactId>
<version>6.1.26</version>
<configuration>
<systemProperties>
<systemProperty>
<name>logback.configurationFile</name>
<value>${project.build.outputDirectory}/jetty-logback.xml</value>
</systemProperty>
</systemProperties>
</configuration>
<dependencies>
<dependency>
<groupId>org.slf4j</groupId>
<artifactId>slf4j-api</artifactId>
<version>1.6.4</version>
</dependency>
<dependency>
<groupId>ch.qos.logback</groupId>
<artifactId>logback-classic</artifactId>
<version>1.0.0</version>
</dependency>
</dependencies>
</plugin>

关于maven - 使用 maven-jetty-plugin 进行 logback 日志记录,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/8087794/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com