SpringBootでログバックを無効にする


118

SpringbootはTomcatでLogbackを使用するように自動設定するようです。これを無効にして、クラスパスで提供したものを使用します。

以下のエラーメッセージ。

LoggerFactoryはLogback LoggerContextではありませんが、Logbackはクラスパス上にあります。Logbackまたは競合する実装(org.slf4j.impl.SimpleLoggerFactoryクラス)のいずれかを削除します。クラス[org.slf4j.impl.SimpleLoggerFactory]のオブジェクトは、クラスch.qos.logback.classic.LoggerContextのインスタンスでなければなりません

<?xml version="1.0" encoding="UTF-8"?>
<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/xsd/maven-4.0.0.xsd">
    <modelVersion>4.0.0</modelVersion>
    <parent>
        <artifactId>spring-boot-starter-parent</artifactId>
        <groupId>org.springframework.boot</groupId>
        <version>1.0.1.RELEASE</version>
    </parent>

    <groupId>com.fe</groupId>
    <artifactId>cloudapp</artifactId>
    <version>1.0.0</version>
    <name>Withinet-PaaS</name>
    <description>Develop your web applications in on our infrastructure and we will worry about administration and scalability of your app.</description>

    <properties>
        <java.version>1.7</java.version>
        <guava.version>16.0.1</guava.version>
        <project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
        <project.reporting.outputEncoding>UTF-8</project.reporting.outputEncoding>
    </properties>

    <dependencies>
    <dependency>
        <groupId>com.sun.jersey</groupId>
        <artifactId>jersey-client</artifactId>
        <version>1.8</version>
    </dependency>
        <dependency>
        <groupId>com.withinet.cloudapp</groupId>
    <artifactId>slave</artifactId>
    <version>1.0.0</version>    
        </dependency>
        <dependency>
            <groupId>org.apache.wicket</groupId>
            <artifactId>wicket-core</artifactId>
            <version>6.15.0</version>
        </dependency>
        <dependency>
            <groupId>org.hibernate</groupId>
            <artifactId>hibernate-core</artifactId>
            <version>4.3.0.Final</version>
        </dependency>

        <dependency>
            <groupId>com.google.code.gson</groupId>
            <artifactId>gson</artifactId>
            <version>2.2.4</version>
        </dependency>

        <!-- Spring Boot -->

        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter</artifactId>
        </dependency>

        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-test</artifactId>
            <scope>test</scope>
        </dependency>

        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-web</artifactId>
        </dependency>

        <!-- Hibernate validator -->

        <dependency>
            <groupId>javax.validation</groupId>
            <artifactId>validation-api</artifactId>
            <version>1.1.0.Final</version>


        </dependency>
        <dependency>
            <groupId>org.hibernate</groupId>
            <artifactId>hibernate-validator-annotation-processor</artifactId>
            <version>4.1.0.Final</version>
        </dependency>

        <!-- Guava -->

        <dependency>
            <groupId>com.google.guava</groupId>
            <artifactId>guava</artifactId>
            <version>${guava.version}</version>
        </dependency>

        <!-- Java EE -->

        <dependency>
            <groupId>javax.inject</groupId>
            <artifactId>javax.inject</artifactId>
            <version>1</version>
        </dependency>

        <!--  Search -->
        <dependency>
            <groupId>org.apache.lucene</groupId>
            <artifactId>lucene-queryparser</artifactId>
            <version>4.8.0</version>
        </dependency>

        <!--  Security 
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-security</artifactId>
        </dependency>-->
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-tomcat</artifactId>
            <scope>provided</scope>
        </dependency>
    </dependencies>

    <build>

        <plugins>

            <!-- Spring Boot Maven -->

            <plugin>
                <groupId>org.springframework.boot</groupId>
                <artifactId>spring-boot-maven-plugin</artifactId>
                <configuration>
                    <mainClass>com.withinet.cloud.Application</mainClass>
                    <layout>JAR</layout>
                </configuration>
                <executions>
                    <execution>
                        <goals>
                            <goal>repackage</goal>
                        </goals>
                    </execution>
                </executions>
            </plugin>

        </plugins>
    </build>
</project>

回答:


143

競合を解決するには、spring-boot-starterとspring-boot-starter-webの両方に除外を追加します。

<dependency>
  <groupId>org.springframework.boot</groupId>
  <artifactId>spring-boot-starter</artifactId>
  <exclusions>
    <exclusion>
      <groupId>org.springframework.boot</groupId>
      <artifactId>spring-boot-starter-logging</artifactId>
    </exclusion>
  </exclusions>
</dependency>

<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>

3
これらの除外を追加すると、次のようになるため、機能しませんjava.lang.ClassNotFoundException: org.apache.commons.logging.LogFactory
アリエル

2
これを行うと、クラスパスに独自のロガー(log4jなど)を提供する必要があります。アプリケーションからデフォルトのロガーを除外したいのはなぜですか?
FOO 2014

1
各jarで「探索」を行わずに、どのjarがログバックを宣言しているのかを見つける方法はありますか?ありがとう!これは私に役立ちました
vivek_ganesan

4
mvn dependency:tree -Dverbose -Dincludes = spring-boot-starter-logging
FOO

この除外を各spring-boot-starter- *依存関係に追加する必要があるのは、非常に面倒です。Gradleは少なくともグローバルな除外を許可しているようです。これだけでも、Mavenからの切り替えを真剣に検討しています。
scottysseus

59

Gradleでより一般的なソリューションを追加するには(すべてのインスタンスが除外されます):

configurations {
    all*.exclude module : 'spring-boot-starter-logging'
}

https://docs.gradle.org/current/userguide/dependency_management.htmlから


1
それは私と少なくとも7人の他の人に有効です。私はあなたの構成または環境の問題が私の解決策への反対投票であるべきだとは思いません(私が受け取った反対投票はあなたのコメントからのものだったと思います-私が間違っていれば申し訳ありません)。
HankCa 2016年

1
他のすべてのconfigsを試してみましたが、これは私のために働いていた唯一のものである
timothyclifford

これは機能しません。まだ表示されますspring-boot-starter-logging
Adam Arold

40

Gradleにソリューションを追加します。

dependencies {
    compile ('org.springframework.boot:spring-boot-starter') {
        exclude module : 'spring-boot-starter-logging'
    }
    compile ('org.springframework.boot:spring-boot-starter-web') {
        exclude module : 'spring-boot-starter-logging'
    }
}

14

spring-boot-starter-loggingモジュール全体を除外する必要はないことがわかりました。必要なのは、org.slf4j:slf4j-log4j12モジュールを除外することだけです。

これをGradleビルドファイルに追加すると、問題が解決します。

configurations {
    runtime.exclude group: "org.slf4j", module: "slf4j-log4j12"
    compile.exclude group: "org.slf4j", module: "slf4j-log4j12"
}

詳細については、この別のStackOverflow 回答を参照してください。


11

私はこれを私の問題を解決するために好きです

<dependency>
    <groupId>org.springframework.boot</groupId>
    <artifactId>spring-boot-starter-log4j</artifactId>
    <exclusions>
        <exclusion>
            <groupId>org.slf4j</groupId>
            <artifactId>slf4j-log4j12</artifactId>
        </exclusion>
    </exclusions>
</dependency>


9

pom.xmlでspring-boot-starter-testを見つけて、次のように変更します。

    <dependency>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-test</artifactId>
        <exclusions>
            <exclusion>
                <artifactId>commons-logging</artifactId>
                <groupId>commons-logging</groupId>
            </exclusion>
        </exclusions>
        <scope>test</scope>
    </dependency>

それは次のようなエラーを修正しました:

_Caused by: java.lang.IllegalArgumentException:_ **LoggerFactory** is not a **Logback LoggerContext** but *Logback* is on the classpath.

Either remove **Logback** or the competing implementation

(_class org.apache.logging.slf4j.Log4jLoggerFactory_
loaded from file: 

**${M2_HOME}/repository/org/apache/logging/log4j/log4j-slf4j-impl/2.6.2/log4j-slf4j-impl-2.6.2.jar**).

If you are using WebLogic you will need to add **'org.slf4j'** to prefer-application-packages in WEB-INF/weblogic.xml: **org.apache.logging.slf4j.Log4jLoggerFactory**

7

次の作品

<dependency>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter</artifactId>
        <exclusions>
            <exclusion>
                <groupId>org.springframework.boot</groupId>
                <artifactId>spring-boot-starter-logging</artifactId>
            </exclusion>
        </exclusions>
    </dependency>

これでも、最終的なアーティファクトにログバックJARが表示されていました(BootのMavenプラグインの代わりにAssemblyプラグインを使用していたため、実際にBootパッケージで機能するかどうかは不明です)
Janaka Bandara

7

あなたが好むロガーが正確に何であるか、そしてあなたがそれを試しインストールするためにあなたがしたことを言うならそれは助けになるかもしれません。とにかく、Spring Bootはクラスパスにあるものを処理しようとするため、ログバックが必要ない場合は、クラスパスから削除してください。docsにlog4jの手順がありますが、同じことが他のサポートされているロギングシステム(slf4j、log4j、java util)にも当てはまります。


3
私はslf4jを使用していますが、私のmaven pomファイルにlogbackが表示されません。
FOO 2014年

Logback slf4jロガーです。多分あなたはあなたのポンを共有することができますか?
Dave Syer 14年

他のslf4j実装を明示的に見ることができないので、それは推移的に来ている必要があります。m2e(Eclipse)や "mvn dependency:tree"などのツールを使用して、依存関係を視覚化できます。Eclipseツールには、依存関係を除外するためのGUIもあります(依存関係を除外するためにGUIが必要です)。完全なslf4j(jclブリッジを含む)がすでにある場合は、「spring-boot-starter-logging」を除外するだけで十分な場合があります。
Dave Syer 14年

5

私はこれで以下のように私の問題を解決しました:

compile('org.mybatis.spring.boot:mybatis-spring-boot-starter:1.3.0'){
    exclude module: 'log4j-slf4j-impl'
    exclude module: 'logback-classic'
}
compile('org.springframework.boot:spring-boot-starter-web'){
    exclude module: 'log4j-slf4j-impl'
    exclude module: 'logback-classic'
}

5

これは私にとってはうまくいきました

configurations {
    all*.exclude module : 'spring-boot-starter-logging'
}

しかし、mavenユーザーにはうまくいきません。私の依存関係はすべてlibs.gradleにあり、他のファイルには必要ありませんでした。したがって、この問題は、を追加することexclude module : 'spring-boot-starter-logging解決されspring-boot-starter-data-jpaspring-boot-starter-test実質的にはすべてブートワードが含まれます。

更新

私の新しいプロジェクトにはアップデートが必要でしたが、spring-boot-starter-test1.5と古いものにはありませんでしたspring-boot-starter-logging。2.0にあります


5

私の場合、spring-boot-starter-loggingアーティファクトを除外する必要があるのはspring-boot-starter-security

これは、次の依存関係を含む、新しく生成されたSpring Boot 2.2.6.RELEASEプロジェクトにあります。

  • 春ブートスターターセキュリティ
  • spring-boot-starter-validation
  • 春ブートスターターウェブ
  • 春ブートスターターテスト

を実行mvn dependency:treeして探して みましたch.qos.logback

<dependencies>私に関連する春のブーツはpom.xml次のようになります:

    <dependency>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-security</artifactId>
        <exclusions>
            <exclusion>
                <groupId>org.springframework.boot</groupId>
                <artifactId>spring-boot-starter-logging</artifactId>
            </exclusion>
        </exclusions>           
    </dependency>

    <dependency>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-log4j2</artifactId>
    </dependency>

    <dependency>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-validation</artifactId>
    </dependency>

    <dependency>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-web</artifactId>
    </dependency>

    <dependency>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-devtools</artifactId>
        <scope>runtime</scope>
        <optional>true</optional>
    </dependency>

    <dependency>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-configuration-processor</artifactId>
        <optional>true</optional>
    </dependency>

    <dependency>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-test</artifactId>
        <scope>test</scope>
        <exclusions>
            <exclusion>
                <groupId>org.junit.vintage</groupId>
                <artifactId>junit-vintage-engine</artifactId>
            </exclusion>
        </exclusions>
    </dependency>

    <dependency>
        <groupId>org.springframework.security</groupId>
        <artifactId>spring-security-test</artifactId>
        <scope>test</scope>
    </dependency>



</dependencies>

これは、spring-boot-starter-loggingを除外した後に機能しました
Prateek Mehta

4

これをbuild.gradleに追加します

configurations.all {
    exclude group: 'org.springframework.boot', module: 'spring-boot-starter-tomcat'
    exclude group: 'org.springframework.boot', module: 'spring-boot-starter-logging'
    exclude group: 'org.springframework.boot', module: 'logback-classic'
}

2

log4j2を使用しようとしたときにこのエラーがSpringBootで発生した場合は、次の手順を実行します。

  • この「excludeGroupIds log4j-slf4j-impl / excludeGroupIds」を追加して、パッケージング中にjarを削除します
  • コマンド「mvndependecy:tree」を使用して、どのライブラリが「logback-classic」に依存しているかを確認します
  • あなたがそれを見つけたところはどこでもそれを依存から除外します。

このエラーは、logbackがlog4j2の変更をオーバーライドするために発生しました。SO4 log2j2を使用する場合は、logbackライブラリと依存関係を削除する必要があります。

これが誰かを助けることを願っています。


2

デフォルトのロギングを除外する正しい方法、およびロギング用にlog4jを構成します。

<dependency>
 <groupId>org.springframework.boot</groupId>
 <artifactId>spring-boot-starter</artifactId>
 <exclusions>
     <exclusion>
     <groupId>org.springframework.boot</groupId>
     <artifactId>spring-boot-starter-logging</artifactId>
     </exclusion>
 </exclusions>
</dependency>

Spring Logging-How Toを参照してください。


1

Netbeans IDEからのログバックの除外を追加するには

  1. > プロジェクトのプロジェクトエクスプローラーセクションにアクセスします。
  2. > 依存関係に進みます以下に表示されるようます
  3. 「spring-boot-starter-logging-XXXjar」をトレースします
  4. jarを右クリックして、以下に示すように[依存関係除外 ]を選択します。これにより、pom.xmlのlogback jarは次のように除外されます。

      <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>
    

ここに画像の説明を入力してください


1

私の場合、以下の除外が機能します!!

    <dependency>
        <groupId>com.xyz.util</groupId>
        <artifactId>xyz-web-util</artifactId>
        <exclusions>
            <exclusion>
                <groupId>org.slf4j</groupId>
                <artifactId>slf4j-log4j12</artifactId>
            </exclusion>
        </exclusions>
    </dependency>

1

除外を追加するだけでは不十分でした。私は偽の瓶を用意しなければなりませんでした:

    <dependency>
        <groupId>ch.qos.logback</groupId>
        <artifactId>logback-classic</artifactId>
        <scope>system</scope>
        <systemPath>${project.basedir}/empty.jar</systemPath>
    </dependency>

1

その理由は、キャメルはlog4jを使用するのに対し、春のブートにはデフォルトのログ構成としてlogbackが付属しています。それが紛争の理由です。上記の回答で述べたように、春のブートからlogbackを削除するか、ラクダからlog4jを削除するかの2つのオプションがあります。

<dependency>
            <groupId>org.apache.camel</groupId>
            <artifactId>camel-spring-boot-starter</artifactId>
            <version>${camel.version}</version>
            <exclusions>
                <exclusion>
                    <groupId>org.slf4j</groupId>
                    <artifactId>slf4j-log4j12</artifactId>
                </exclusion>
            </exclusions>
        </dependency>

0

クラスパスにlogback.xml設定を追加し、ルートアペンダーを追加してすべての設定を追加するだけです。SpringブートがBeanのロードを完了すると、構成に基づいてロギングが開始されます。

弊社のサイトを使用することにより、あなたは弊社のクッキーポリシーおよびプライバシーポリシーを読み、理解したものとみなされます。
Licensed under cc by-sa 3.0 with attribution required.