Если я избавлюсь от предупреждения «Несколько привязок SLF4J», запись перестанет работать - PullRequest
8 голосов
/ 06 января 2012

У меня есть следующая структура каталогов в Tomcat 6:

tomcat
|-lib
|  |- logback-classic.jar
|  |- logback-core.jar
|  |- slf4j-api.jar
|  |- myState.jar
|-shared
|  |-lib
|  |  |- myStateLogback.xml
|-webapps
|  |-myApp
|  |  |-WEB-INF
|  |  |  |-logback.xml
|  |  |  |-lib
|  |  |  |  |-jcl-over-slf4j.jar
|  |  |  |  |-logback-classic.jar
|  |  |  |  |-logback-core.jar
|  |  |  |  |-slf4j-api.jar

myState.jar должен находиться в каталоге tomcat / lib, поскольку он содержит классы, необходимые для запуска tomcat в качестве глобального ресурса. Он записывает свои записи в slf4j, поэтому также нужны файлы jar slf4j и logback. Он использует JoranConfigurator для загрузки myStateLogback.xml.

myApp webapp пишет, что ведение журнала ведется в общем журнале, но я хочу, чтобы он прошел через slf4j для входа в систему, чтобы подготовить перенос всей нашей регистрации в slf4j, поэтому я использую мост jcl-over-slf4j.

При вышеописанной настройке ведение журнала все работает, но при запуске появляется следующее предупреждение:

SLF4J: Class path contains multiple SLF4J bindings.
SLF4J: Found binding in [jar:file:/D:/tomcat/lib/logback-classic-0.9.29.jar!/org/slf4j/impl/StaticLoggerBinder.class]
SLF4J: Found binding in [jar:file:/D:/tomcat/webapps/myApp/WEB-INF/lib/logback-classic-0.9.29.jar!/org/slf4j/impl/StaticLoggerBinder.class]

Если я возьму logback-classic из библиотеки lib веб-приложения, я получу следующее исключение:

Exception in thread "Timer-30" java.lang.LinkageError: loader constraint violation: when resolving method "org.slf4j.impl.StaticLoggerBinder.getLoggerFactory()Lorg/slf4j/ILoggerFactory;" the class loader (instance of org/apache/catalina/loader/WebappClassLoader) of the current class, org/slf4j/LoggerFactory, and the class loader (instance of org/apache/catalina/loader/StandardClassLoader) for resolved class, org/slf4j/impl/StaticLoggerBinder, have different Class objects for the type org/slf4j/ILoggerFactory used in the signature
        at org.slf4j.LoggerFactory.getILoggerFactory(LoggerFactory.java:284)
        at org.slf4j.LoggerFactory.getLogger(LoggerFactory.java:252)
        at org.apache.commons.logging.impl.SLF4JLogFactory.getInstance(SLF4JLogFactory.java:156)
        at org.apache.commons.logging.impl.SLF4JLogFactory.getInstance(SLF4JLogFactory.java:132)
        at org.apache.commons.logging.LogFactory.getLog(LogFactory.java:272)

Если я удаляю 2 jar-файла logback и файл slf4j-api.jar из каталога lib веб-приложения, я не получаю никаких предупреждений и исключений, но логи из моего веб-приложения выбираются файлом myStateLogback.xml и переходят к это регистратор, который я не хочу. Я знаю, что могу отфильтровать нежелательные утверждения, но я хочу иметь отдельные файлы конфигурации для веб-приложения и фляги. Есть ли способ добиться этого?

Я использую Tomcat 6.0.23, logback 0.9.29 и slf4j 1.6.3.

Спасибо, Сара

Ответы [ 2 ]

3 голосов
/ 07 января 2012

В документации по возврату есть глава под названием разделение журналов , в которой представлено одно возможное решение.

1 голос
/ 27 января 2015

Использование новой опции -Dlogback.debug = true покажет сообщения от того, что выглядит как slf4j-api, в поисках своих реализаций. (Ведение журнала выглядит для меня как любимая мозоль в мире Java).

09:12:05,472 |-INFO in ch.qos.logback.classic.LoggerContext[default] - Could NOT find resource [logback.groovy]
09:12:05,472 |-INFO in ch.qos.logback.classic.LoggerContext[default] - Found resource [logback-test.xml] at [jar:file:/home/FOO/BAR.jar!/logback-test.xml]
09:12:05,487 |-INFO in ch.qos.logback.core.joran.spi.ConfigurationWatchList@2c8d66b2 - URL [jar:file:/home/FOO/BAR.jar!/logback-test.xml] is not of type file
09:12:05,656 |-INFO in ch.qos.logback.core.joran.action.AppenderAction - About to instantiate appender of type [ch.qos.logback.core.ConsoleAppender]
09:12:05,662 |-INFO in ch.qos.logback.core.joran.action.AppenderAction - Naming appender as [STDOUT]
09:12:05,700 |-INFO in ch.qos.logback.core.joran.action.NestedComplexPropertyIA - Assuming default type [ch.qos.logback.classic.encoder.PatternLayoutEncoder] for [encoder] property
09:12:05,729 |-INFO in ch.qos.logback.classic.joran.action.LoggerAction - Setting level of logger [org.mongodb.morphia.mapping.Mapper] to ERROR
09:12:05,729 |-INFO in ch.qos.logback.classic.joran.action.LoggerAction - Setting level of logger [com.BAZ] to DEBUG
09:12:05,729 |-INFO in ch.qos.logback.classic.joran.action.RootLoggerAction - Setting level of ROOT logger to INFO
09:12:05,730 |-INFO in ch.qos.logback.core.joran.action.AppenderRefAction - Attaching appender named [STDOUT] to Logger[ROOT]
09:12:05,730 |-INFO in ch.qos.logback.classic.joran.action.ConfigurationAction - End of configuration.
09:12:05,732 |-INFO in ch.qos.logback.classic.joran.JoranConfigurator@58651fd0 - Registering current configuration as safe fallback point
...