Chcę użyć logback logowania z maven-jetty-plugin. Najwyraźniej właściwość systemowa logback.configurationFile jest odczytywana po uruchomieniu maven-jetty-plugin i zainicjowała slf4j, więc plik ./src/test/resources/logback.xml nie jest czytany przez pomost. W rezultacie otrzymuję wszystkie komunikaty dziennika ustawione na poziom debugowania i drukowane na konsoli (domyślna konfiguracja logback). Uruchomienie maven za pomocą -Dlogback.configurationFile = ... rozwiązuje problem. Jednak wolałbym ustawić właściwość w pom, jak to jest możliwe z log4j i maven-jetty-plugin. Jakieś pomysły ?Rejestrowanie logback z maven-jetty-plugin
Oto moja 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>
...
A oto 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>
Ładna i czysta odpowiedź. Dla porównania robię coś podobnego za pomocą Gradle'a: http://thegreenoak.blogspot.com/2013/02/using-slf4j-and-logback-with-gradle.html – djangofan