2017-02-10 23 views
0

Мы столкнулись с конфликтами версии sl4j в градиенте со Storm 1.0.1 и elasticsearch 5.2.конфликты версии sl4j в градиенте со Storm 1.0.1 и elasticsearch 5.2

Мы обнаружили, что ElasticSearch нуждается в мосту log4j-to-slf4j, чтобы мы могли использовать нужные регистраторы. Здесь мы пытаемся использовать logback-classic с slf4j.

зависимостей определены как показано ниже:

dependencies { 
    compile 'org.slf4j:slf4j-api:1.7.21' 
    compile 'org.apache.logging.log4j:log4j-to-slf4j:2.6.2' 
    compile 'ch.qos.logback:logback-classic:1.1.10' 
    provided ('org.apache.storm:storm-core:1.0.1') { 
     exclude(group: 'org.slf4j', module: 'slf4j-api') 
    } 
    compile 'org.elasticsearch:elasticsearch:5.2.0' 
    compile 'org.elasticsearch.client:x-pack-transport:5.2.0' 
} 

Чтобы решить эту проблему, я попытался исключить SLF4J из грозовой ядра и добавить то же самое позднее, как показано ниже:

configurations.all { 
    resolutionStrategy { 
     eachDependency { DependencyResolveDetails dependencyResolveDetails -> 
      final requestedDependency = dependencyResolveDetails.requested 
      if (requestedDependency.group == 'org.slf4j' && requestedDependency.name == 'slf4j-api') { 
       requestedDependency.setVersion "1.7.7" 
      } 
     } 
    } 
} 

Но когда топология мы получаем ошибку: SLF4J: Путь класса содержит несколько привязок SLF4J. SLF4J: Найдено привязка в [jar: файл: /Users/gauthamr05/Documents/Apps/Storm/apache-storm-1.0.1/lib/log4j-slf4j-impl-2.1.jar!/Org/slf4j/impl/StaticLoggerBinder .class] SLF4J: Найдено привязку в [jar: файл: /Users/gauthamr05/Documents/workspace/xyz_app/build/libs/FullIndexing.jar !/org/slf4j/impl/StaticLoggerBinder.class] SLF4J: см. http://www.slf4j.org/codes.html#multiple_bindings для объяснение. SLF4J: Фактическое связывание типа [org.apache.logging.slf4j.Log4jLoggerFactory] Исключение в потоке "основного" java.lang.StackOverflowError на org.apache.logging.log4j.spi.LoggerRegistry.getOrCreateInnerMap (LoggerRegistry.java : 140) at org.apache.logging.log4j.spi.LoggerRegistry.hasLogger (LoggerRegistry.java:154) at org.apache.logging.slf4j.SLF4JLoggerContext.getLogger (SLF4JLoggerContext.java:38) at org.apache .logging.slf4j.Log4jLoggerFactory.newLogger (Log4jLoggerFactory.java:37) at org.apache.logging.slf4j.Log4jLoggerFactory.newLogger (Log4jLoggerFactory.java:29) at org.apache.logging.log4j.spi.AbstractLoggerAdapter.getLogger (AbstractLoggerAdapter.java:47) at org.apache.logging.slf4j.Log4jLogg erFactory.getLogger (Log4jLoggerFactory.java:29) в org.slf4j.LoggerFactory.getLogger (LoggerFactory.java:277)

ответ

0

Как говорится исключения, есть две банки, содержащие StaticLoggerBinder.class.

  • /Users/gauthamr05/Documents/Apps/Storm/apache-storm-1.0.1/lib/log4j-slf4j-impl-2.1.jar
  • /Пользователи/gauthamr05/Документы/рабочее пространство/xyz_app/build/libs/FullIndexing.jar

Вопрос: Есть xyz_app/build/libs/FullIndexing.jar один из ваших собственных проектов?

Если это ваша собственная банка, я немного предполагаю здесь, но я предполагаю, что org/slf4j/impl/StaticLoggerBinder.java упакован в одну из банок на пути к классу. Существует wierd default javac, где он скомпилирует любые файлы .java, найденные в банках вашего пути к классам. Это может быть выключено с помощью

compileJava.options.compilerArgs << '-implicit:none' 

См here и here

0

Найден способ тени классов log4j в конечном банке.

Ниже приведены конфигурации:

apply plugin: 'com.github.johnrengelman.shadow' 

subprojects { 
    shadowJar 
} 

dependencies { 
    compile 'org.slf4j:slf4j-api:1.7.22' 
    compile 'ch.qos.logback:logback-classic:1.1.10' 

    compileOnly("org.apache.storm:storm-core:1.0.1") { 
     exclude module: "log4j-slf4j-impl" 
     exclude module: "slf4j-api" 
     exclude module: "log4j-to-slf4j" 
    } 

    // ElasticSearch and X-Pack 
    compile 'org.elasticsearch:elasticsearch:5.2.0' 
    compile 'org.elasticsearch.client:x-pack-transport:5.2.0' 

    compile 'org.apache.logging.log4j:log4j-api:2.7' 
    compile 'org.apache.logging.log4j:log4j-core:2.7' 
} 

shadowJar { 
    relocate 'org.apache.logging.log4j', 'gautham.elasticsearch.org.apache.logging.log4j' 

    zip64 true 
    transform(ServiceFileTransformer) { 
     path = 'META-INF/vesta*' 
    } 

    manifest { 
     attributes 'Implementation-Title': 'Storm Topology', 
      'Implementation-Version': 1.0, 
      'Main-Class': 'com.gautham.topology.StormTopology' 
    } 

    baseName = 'StormTopology' 

    mergeServiceFiles() 

    exclude "META-INF/*.SF" 
    exclude 'META-INF/*.DSA' 
    exclude 'META-INF/*.RSA' 
    exclude "LICENSE*" 
} 

 Смежные вопросы

  • Нет связанных вопросов^_^