私はチュートリアルに従っています https://spring.io/guides/gs/actuator-service/
そして、私がアプリを実行しようとすると、次のようになります:
SLF4J LoggerFactoryのインスタンス化に失敗しました報告された例外:Java.lang.NoClassDefFoundError:ch/qos/logback/core/joran/spi/JoranException at org.slf4j.LoggerFactory.bind(LoggerFactory.Java:150)org.slf4j.LoggerFactory.performInitialization (LoggerFactory.Java:124)at org.slf4j.LoggerFactory.getILoggerFactory(LoggerFactory.Java:412)at org.slf4j.LoggerFactory.getLogger(LoggerFactory.Java:357)at org.Apache.commons.logging.impl.SLF4JLogFactory。 getInstance(SLF4JLogFactory.Java:155)at org.Apache.commons.logging.impl.SLF4JLogFactory.getInstance(SLF4JLogFactory.Java:132)at org.Apache.commons.logging.LogFactory.getLog(LogFactory.Java:273)at org .springframework.boot.SpringApplication。(SpringApplication.Java:189)at hello.HelloWorldConfiguration.main(HelloWorldConfiguration.Java:11)原因:Java.lang.ClassNotFoundException:ch.qos.logback.core.joran.spi.JoranException at Java.net.URLClassLoader.findClass(URLClassLoader.Java:381)at Java.lang.ClassLoader.loadClass(ClassLoader.Java:424) Sun.misc.Launcher $ AppClassLoader.loadClass(Launcher.Java:331)at Java.lang.ClassLoader.loadClass(ClassLoader.Java:357)... 9スレッド "main"の例外Java.lang.NoClassDefFoundError:ch/qos/logback/core/joran/spi/JoranException at org.slf4j.LoggerFactory.bind(LoggerFactory.Java:150)at org.slf4j.LoggerFactory.performInitialization(LoggerFactory.Java:124)at org.slf4j.LoggerFactory.getILoggerFactory (LoggerFactory.Java:412)at org.slf4j.LoggerFactory.getLogger(LoggerFactory.Java:357)at org.Apache.commons.logging.impl.SLF4JLogFactory.getInstance(SLF4JLogFactory.Java:155)at org.Apache.commons。 logging.impl.SLF4JLogFactory.getInstance(SLF4JLogFactory.Java:132)at org.Apache.commons.logging.LogFactory.getLog(LogFactory.Java:273)at org.springframework.boot.SpringApplication。(SpringApplication.Java:189)at hello.HelloWorldConfiguration.main(HelloWorldConfiguration.Java:11)原因:Java.lang.ClassNotFoundException:ch.qos.logback.core.joran.spi.JoranException at Java.net.URLClassL oader.findClass(URLClassLoader.Java:381)at Java.lang.ClassLoader.loadClass(ClassLoader.Java:424)at Sun.misc.Launcher $ AppClassLoader.loadClass(Launcher.Java:331)at Java.lang.ClassLoader.loadClass (ClassLoader.Java:357)... 9以上
私のpomファイルは次のようになります。
<project xmlns="http://maven.Apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://maven.Apache.org/POM/4.0.0 http://maven.Apache.org/maven-v4_0_0.xsd">
<modelVersion>4.0.0</modelVersion>
<parent>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-parent</artifactId>
<version>1.4.1.RELEASE</version>
</parent>
<groupId>sample.api</groupId>
<artifactId>api.test</artifactId>
<version>0.0.1-SNAPSHOT</version>
<name>api.testMaven Webapp</name>
<url>http://maven.Apache.org</url>
<dependencies>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-web</artifactId>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-actuator</artifactId>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-test</artifactId>
<scope>test</scope>
</dependency>
</dependencies>
<properties>
<Java.version>1.8</Java.version>
</properties>
<build>
<finalName>api.test</finalName>
<plugins>
<plugin>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-maven-plugin</artifactId>
</plugin>
</plugins>
</build>
</project>
そして、私はこの問題を修正する方法に途方に暮れています。私はクリーニングして再構築し、再インポートも試みました。 this のような同様の質問を見ましたが、何も機能しないようです。
プログラムを実行させる唯一の方法は、親pomをバージョン1.3.1.RELEASE
に変更することでしたが、このバージョンを使用したくなく、1.4.1.RELEASE
を使用したい
どんな助けでも大歓迎です。
ここにmvnの依存関係があります:ツリー
[INFO] --- maven-dependency-plugin:2.10:tree (default-cli) @ api.test ---
[INFO] sample.api:api.test:jar:0.0.1-SNAPSHOT
[INFO] +- org.springframework.boot:spring-boot-starter-web:jar:1.4.1.RELEASE:com
pile
[INFO] | +- org.springframework.boot:spring-boot-starter:jar:1.4.1.RELEASE:comp
ile
[INFO] | | +- org.springframework.boot:spring-boot:jar:1.4.1.RELEASE:compile
[INFO] | | +- org.springframework.boot:spring-boot-autoconfigure:jar:1.4.1.REL
EASE:compile
[INFO] | | +- org.springframework.boot:spring-boot-starter-logging:jar:1.4.1.R
ELEASE:compile
[INFO] | | | +- ch.qos.logback:logback-classic:jar:1.1.7:compile
[INFO] | | | +- org.slf4j:jcl-over-slf4j:jar:1.7.21:compile
[INFO] | | | +- org.slf4j:jul-to-slf4j:jar:1.7.21:compile
[INFO] | | | \- org.slf4j:log4j-over-slf4j:jar:1.7.21:compile
[INFO] | | \- org.yaml:snakeyaml:jar:1.17:runtime
[INFO] | +- org.springframework.boot:spring-boot-starter-Tomcat:jar:1.4.1.RELEA
SE:compile
[INFO] | | +- org.Apache.Tomcat.embed:Tomcat-embed-core:jar:8.5.5:compile
[INFO] | | +- org.Apache.Tomcat.embed:Tomcat-embed-el:jar:8.5.5:compile
[INFO] | | \- org.Apache.Tomcat.embed:Tomcat-embed-websocket:jar:8.5.5:compile
[INFO] | +- org.hibernate:hibernate-validator:jar:5.2.4.Final:compile
[INFO] | | +- javax.validation:validation-api:jar:1.1.0.Final:compile
[INFO] | | +- org.jboss.logging:jboss-logging:jar:3.3.0.Final:compile
[INFO] | | \- com.fasterxml:classmate:jar:1.3.1:compile
[INFO] | +- com.fasterxml.jackson.core:jackson-databind:jar:2.8.3:compile
[INFO] | | +- com.fasterxml.jackson.core:jackson-annotations:jar:2.8.3:compile
[INFO] | | \- com.fasterxml.jackson.core:jackson-core:jar:2.8.3:compile
[INFO] | +- org.springframework:spring-web:jar:4.3.3.RELEASE:compile
[INFO] | | +- org.springframework:spring-aop:jar:4.3.3.RELEASE:compile
[INFO] | | +- org.springframework:spring-beans:jar:4.3.3.RELEASE:compile
[INFO] | | \- org.springframework:spring-context:jar:4.3.3.RELEASE:compile
[INFO] | \- org.springframework:spring-webmvc:jar:4.3.3.RELEASE:compile
[INFO] | \- org.springframework:spring-expression:jar:4.3.3.RELEASE:compile
[INFO] +- org.springframework.boot:spring-boot-starter-actuator:jar:1.4.1.RELEAS
E:compile
[INFO] | \- org.springframework.boot:spring-boot-actuator:jar:1.4.1.RELEASE:com
pile
[INFO] \- org.springframework.boot:spring-boot-starter-test:jar:1.4.1.RELEASE:te
st
[INFO] +- org.springframework.boot:spring-boot-test:jar:1.4.1.RELEASE:test
[INFO] +- org.springframework.boot:spring-boot-test-autoconfigure:jar:1.4.1.R
ELEASE:test
[INFO] +- com.jayway.jsonpath:json-path:jar:2.2.0:test
[INFO] | +- net.minidev:json-smart:jar:2.2.1:test
[INFO] | | \- net.minidev:accessors-smart:jar:1.1:test
[INFO] | | \- org.ow2.asm:asm:jar:5.0.3:test
[INFO] | \- org.slf4j:slf4j-api:jar:1.7.21:compile
[INFO] +- junit:junit:jar:4.12:test
[INFO] +- org.assertj:assertj-core:jar:2.5.0:test
[INFO] +- org.mockito:mockito-core:jar:1.10.19:test
[INFO] | \- org.objenesis:objenesis:jar:2.1:test
[INFO] +- org.hamcrest:hamcrest-core:jar:1.3:test
[INFO] +- org.hamcrest:hamcrest-library:jar:1.3:test
[INFO] +- org.skyscreamer:jsonassert:jar:1.3.0:test
[INFO] | \- org.json:json:jar:20140107:test
[INFO] +- org.springframework:spring-core:jar:4.3.3.RELEASE:compile
[INFO] \- org.springframework:spring-test:jar:4.3.3.RELEASE:test
[INFO] ------------------------------------------------------------------------
追加した場合
<dependency>
<groupId>org.slf4j</groupId>
<artifactId>slf4j-api</artifactId>
<version>1.7.5</version>
</dependency>
<dependency>
<groupId>org.slf4j</groupId>
<artifactId>jcl-over-slf4j</artifactId>
<version>1.7.5</version>
<scope>runtime</scope>
</dependency>
<dependency>
<groupId>org.slf4j</groupId>
<artifactId>slf4j-log4j12</artifactId>
<version>1.7.5</version>
<scope>runtime</scope>
</dependency>
私は得る
SLF4J:クラスパスには複数のSLF4Jバインディングが含まれています。 SLF4J:[jar:file:/ C:/Users/Josh/.m2/repository/ch/qos/logback/logback-classic/1.1.7/logback-classic-1.1.7.jar!/ org /にバインディングが見つかりましたslf4j/impl/StaticLoggerBinder.class] SLF4J:[jar:file:/ C:/Users/Josh/.m2/repository/org/slf4j/slf4j-log4j12/1.7.21/slf4j-log4j12-1.7.21にバインディングが見つかりました.jar!/org/slf4j/impl/StaticLoggerBinder.class] SLF4J:説明は http://www.slf4j.org/codes.html#multiple_bindings を参照してください。 SLF4J LoggerFactoryのインスタンス化に失敗しました報告された例外:Java.lang.NoClassDefFoundError:ch/qos/logback/core/joran/spi/JoranException at org.slf4j.LoggerFactory.bind(LoggerFactory.Java:150)org.slf4j.LoggerFactory.performInitialization (LoggerFactory.Java:124)at org.slf4j.LoggerFactory.getILoggerFactory(LoggerFactory.Java:412)at org.slf4j.LoggerFactory.getLogger(LoggerFactory.Java:357)at org.Apache.commons.logging.impl.SLF4JLogFactory。 getInstance(SLF4JLogFactory.Java:155)at org.Apache.commons.logging.impl.SLF4JLogFactory.getInstance(SLF4JLogFactory.Java:132)at org.Apache.commons.logging.LogFactory.getLog(LogFactory.Java:273)at org .springframework.boot.SpringApplication。(SpringApplication.Java:189)at hello.HelloWorldConfiguration.main(HelloWorldConfiguration.Java:11)原因:Java.lang.ClassNotFoundException:ch.qos.logback.core.joran.spi.JoranException at Java.net.URLClassLoader.findClass(URLClassLoader.Java:381)at Java.lang.ClassLoader.loadClass(ClassLoader.Java:424) Sun.misc.Launcher $ AppClassLoader.loadClass(Launcher.Java:331)at Java.lang.ClassLoader.loadClass(ClassLoader.Java:357)... 9スレッド "main"の例外Java.lang.NoClassDefFoundError:ch/qos/logback/core/joran/spi/JoranException at org.slf4j.LoggerFactory.bind(LoggerFactory.Java:150)at org.slf4j.LoggerFactory.performInitialization(LoggerFactory.Java:124)at org.slf4j.LoggerFactory.getILoggerFactory (LoggerFactory.Java:412)at org.slf4j.LoggerFactory.getLogger(LoggerFactory.Java:357)at org.Apache.commons.logging.impl.SLF4JLogFactory.getInstance(SLF4JLogFactory.Java:155)at org.Apache.commons。 logging.impl.SLF4JLogFactory.getInstance(SLF4JLogFactory.Java:132)at org.Apache.commons.logging.LogFactory.getLog(LogFactory.Java:273)at org.springframework.boot.SpringApplication。(SpringApplication.Java:189)at hello.HelloWorldConfiguration.main(HelloWorldConfiguration.Java:11)原因:Java.lang.ClassNotFoundException:ch.qos.logback.core.joran.spi.JoranException at Java.net.URLClassL oader.findClass(URLClassLoader.Java:381)at Java.lang.ClassLoader.loadClass(ClassLoader.Java:424)at Sun.misc.Launcher $ AppClassLoader.loadClass(Launcher.Java:331)at Java.lang.ClassLoader.loadClass (ClassLoader.Java:357)... 9以上
以下のアクションは私のために働きました
mvn dependency:purge-local-repository
を実行して、すべての依存関係を削除し、強制的に再ダウンロードします。mvn clean verify
を実行しますこの依存関係を追加し、問題を解決しました。
<dependency>
<groupId>ch.qos.logback</groupId>
<artifactId>logback-core</artifactId>
<version>${logback.version}</version>
</dependency>
this エラーが発生した場合は、logback-classicのバージョンを使用するだけです。
Log4jを見つけてクラスパスに追加する必要があります。
この問題はバージョン1.3.5では発生しません。バージョンを変更しました
<parent>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-parent</artifactId>
<version>1.3.5.RELEASE</version>
<relativePath/> <!-- lookup parent from repository -->
</parent>
できます !!
そのメッセージを参照してください:(依存関係の推移性については、依存関係の重複を管理し、異なるバージョンで依存関係の重複を引き起こします)
クラスパスに複数のSLF4Jバインディングが含まれています。 SLF4J:バインディングが見つかりました
IDE Eclipseを使用しているかどうかをテストします
ショートカットキー: Shift+Ctrl+T
これにより、どのファイルにこのクラスが含まれているかがわかります。
SLF4J: Found binding in [jar:file:
/C:/Users/Josh/.m2/repository/ch/qos/logback/logback-classic/1.1.7/logback-classic-1.1.7.jar!
/org/slf4j/impl/StaticLoggerBinder.class]
[jar:file:/C:/Users/Josh/.m2/repository/org/slf4j/slf4j-log4j12/1.7.21/slf4j-log4j12-1.7.21.jar!
/org/slf4j/impl/StaticLoggerBinder.class]
クラスを繰り返す
slf4j-log4j12-1.7.21.jar
logback-classic-1.1.7.jar
プロジェクトで必要ないものと同じ依存関係と除外を見つける
そのように:
<dependency>
<groupId>org.seleniumhq.Selenium</groupId>
<artifactId>Selenium-Java</artifactId>
<version>3.0.0-beta2</version>
<scope>test</scope>
<exclusions>
<exclusion>
<artifactId>xml-apis</artifactId>
<groupId>xml-apis</groupId>
</exclusion>
</exclusions>
その1つの例、状況に応じて変更
依存関係のロギングをスキップできます。これでうまくいきます。
`<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-web</artifactId>
<exclusions>
<exclusion>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-logging</artifactId>
</exclusion>
</exclusions>
</dependency>`
バージョンの問題の可能性があります。スプリングブートのバージョンを2.0.0.RELEASEから1.5.4.RELEASEに変更すると、例外が消えました。
<parent>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-parent</artifactId>
<version>1.5.4.RELEASE</version>
</parent>