Logback variable substitution nicht finden konnte, property Datei im classpath

Ich wirklich wie Logback die Unterstützung, sich in einen DB. Aber ich habe Probleme mit Logback die variable ersetzen-Funktion, genauer gesagt, aus einer property Datei im classpath.

Meine Referenz: http://logback.qos.ch/manual/configuration.html#variableSubstitution

Also ich habe ein multi-Modul-Maven-Projekt. In meinem web-Modul (erzeugt ein .war-Datei), habe ich meine Logback conf-Dateien in das folgende Verzeichnis:

src/main/reesources
- logback.xml
- local.properties
- dev.properties

Meine logback.xml sieht wie folgt aus:

<?xml version="1.0" encoding="UTF-8"?>
<configuration>

    <property file="${env}.properties"/>

    <appender name="STDOUT" class="ch.qos.logback.core.ConsoleAppender">
        <encoder>
            <pattern>%d{HH:mm:ss.SSS} [%X{messageId}] %-5level %logger{0} - %msg%n
            </pattern>
        </encoder>
    </appender>

    <appender name="DB" class="ch.qos.logback.classic.db.DBAppender">
        <connectionSource class="ch.qos.logback.core.db.DataSourceConnectionSource">
            <dataSource class="com.mchange.v2.c3p0.ComboPooledDataSource">
                <driverClass>${logback.db.driverClassName}</driverClass>
                <jdbcUrl>${logback.db.url}</jdbcUrl>
                <user>${logback.db.user}</user>
                <password>${logback.db.password}</password>
            </dataSource>
        </connectionSource>
    </appender>

    <root level="debug">
        <appender-ref ref="DB" />
    </root>
</configuration>

So, wenn ich um den Tomcat-server an, ich würde pass in die ${env} wie diese:

-Denv=local

Allerdings bekam ich die folgende Fehlermeldung, wenn ich brachte den server:

17:45:22,782  WARN com.mchange.v2.async.ThreadPoolAsynchronousRunner$PoolThread-#0 DriverManagerDataSource:107 - Could not load driverClass logback.db.driverClassName_IS_UNDEFINED
java.lang.ClassNotFoundException: logback.db.driverClassName_IS_UNDEFINED
    at org.apache.catalina.loader.WebappClassLoader.loadClass(WebappClassLoader.java:1678)
    at org.apache.catalina.loader.WebappClassLoader.loadClass(WebappClassLoader.java:1523)

Sieht es aus wie Logback Joran hatte Schwierigkeiten beim Auffinden der property-Datei.

Kann jemand lassen Sie mich wissen, was ich falsch gemacht habe?

InformationsquelleAutor der Frage scabbage | 2012-03-30

Schreibe einen Kommentar