ปิดการใช้งาน Logback ใน SpringBoot


118

ดูเหมือนว่า Springboot กำหนดค่าอัตโนมัติเองเพื่อใช้ Logback กับ Tomcat ฉันต้องการปิดใช้งานสิ่งนี้และใช้สิ่งที่ฉันให้ไว้ใน classpath ของฉัน

ข้อความแสดงข้อผิดพลาดด้านล่าง

LoggerFactory ไม่ใช่ Logback LoggerContext แต่ Logback อยู่บน classpath ลบ Logback หรือการนำไปใช้งานที่แข่งขันกัน (class 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มันไม่ทำงานสำหรับฉันเพราะถ้าฉันจะเพิ่มการยกเว้นเหล่านั้นที่ฉันได้รับ:
Ariel

2
เมื่อคุณทำสิ่งนี้คุณจะต้องระบุคนตัดไม้ของคุณเองเช่น log4j ใน classpath ของคุณ เหตุใดคุณจึงต้องการยกเว้นผู้บันทึกเริ่มต้นจากแอปพลิเคชันของคุณ
FOO

1
มีวิธีค้นหาว่าโถใดที่ประกาศการล็อกกลับโดยไม่ต้องทำการ 'สำรวจ' ในแต่ละโถหรือไม่? และขอบคุณ! สิ่งนี้ช่วยฉันได้
vivek_ganesan

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

การต้องเพิ่มการยกเว้นนี้ให้กับการพึ่งพาสปริงบูต - สตาร์ทเตอร์ - * แต่ละครั้งเป็นเรื่องยุ่งยากมาก ดูเหมือนว่าอย่างน้อย 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

1
ได้ลองใช้การกำหนดค่าอื่น ๆ ทั้งหมดนี่เป็นสิ่งเดียวที่ได้ผลสำหรับฉัน
ทิโมธีคลิฟฟอ

ไม่ได้ผลฉันยังคงเห็น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

ค้นหา spring-boot-starter-test ใน pom.xml ของคุณและแก้ไขดังนี้:

    <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 บันทึกย้อนกลับในสิ่งประดิษฐ์สุดท้าย (ใช้ปลั๊กอิน Assembly แทนปลั๊กอิน Boot's Maven - ดังนั้นไม่แน่ใจว่ามันใช้งานได้จริงกับ Boot packaging หรือไม่)
Janaka Bandara

7

อาจช่วยได้ถ้าคุณบอกว่าคนตัดไม้ที่คุณต้องการคืออะไรและคุณได้ลองติดตั้งอะไรบ้าง อย่างไรก็ตาม Spring Boot จะพยายามทำงานกับสิ่งที่อยู่ใน classpath ดังนั้นหากคุณไม่ต้องการบันทึกย้อนกลับให้นำออกจาก classpath มีคำแนะนำสำหรับ log4j ในเอกสารแต่สิ่งเดียวกันนี้จะใช้กับระบบบันทึกอื่น ๆ ที่รองรับ (อะไรก็ได้ที่ slf4j, log4j หรือ java util)


3
ฉันใช้ slf4j และฉันไม่เห็น logback ในไฟล์ maven pom ของฉัน
FOO

Logback คือคนตัดไม้ slf4j บางทีคุณสามารถแบ่งปันปอมของคุณได้?
Dave Syer

ฉันไม่เห็นการใช้งาน slf4j อื่น ๆ อย่างชัดเจนดังนั้นจึงต้องเข้ามาในสกรรมกริยา คุณสามารถใช้เครื่องมือเช่น m2e (Eclipse) หรือ "mvn dependency: tree" เพื่อแสดงภาพการอ้างอิง เครื่องมือ Eclipse ยังมี GUI สำหรับยกเว้นการอ้างอิง (นั่นคือสิ่งที่คุณต้องทำ - ไม่รวมหนึ่งในนั้น) อาจไม่เพียงพอที่จะยกเว้น "spring-boot-starter-logging" หากคุณมี slf4j ที่สมบูรณ์อยู่แล้ว (รวมถึงสะพาน jcl)
Dave Syer

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-jpa, spring-boot-starter-testและในทางปฏิบัติทุกอย่างที่มีคำบูต

UPDATE

โครงการใหม่ของฉันจำเป็นต้องมีการปรับปรุงจะเปิดออกspring-boot-starter-test1.5 spring-boot-starter-loggingและรุ่นเก่าไม่ได้มี 2.0 ได้เลย


5

ในกรณีของฉันจำเป็นต้องแยกอาร์ติspring-boot-starter-loggingแฟกต์ออกจากไฟล์spring-boot-starter-securityเท่านั้น

นี่คือในสปริงบูต 2.2.6 รีเลสโปรเจ็กต์ที่สร้างขึ้นใหม่รวมถึงการอ้างอิงต่อไปนี้

  • ฤดูใบไม้ผลิบูตเริ่มต้นการรักษาความปลอดภัย
  • ฤดูใบไม้ผลิบูตเริ่มต้นการตรวจสอบ
  • ฤดูใบไม้ผลิบูตเริ่มต้นเว็บ
  • ฤดูใบไม้ผลิบูตเริ่มต้นการทดสอบ

ฉันค้นพบโดยการวิ่ง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>

มันใช้งานได้หลังจากไม่รวมสปริงบูต - สตาร์ท - ล็อก
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

หากข้อผิดพลาดนี้เกิดขึ้นใน SpringBoot เมื่อคุณพยายามใช้ log4j2 ให้ทำตามขั้นตอนเหล่านี้:

  • นำ jar ออกจากขณะที่ packeging โดยเพิ่ม "excludeGroupIds log4j-slf4j-im / excludeGroupIds"
  • ค้นหาว่าไลบรารีใดขึ้นอยู่กับ "logback-classic" โดยใช้คำสั่ง "mvn dependecy: tree"
  • ทุกที่ที่คุณพบว่ามันแยกออกจากการพึ่งพา

ข้อผิดพลาดนี้เกิดขึ้นเนื่องจากการบันทึกกลับแทนที่การเปลี่ยนแปลง log4j2 ดังนั้นหากคุณต้องการใช้ log4j2 คุณต้องลบไลบรารีการล็อกแบ็คและการอ้างอิง

หวังว่านี่จะช่วยใครบางคนได้


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>

อ้างถึงฤดูใบไม้ผลิเข้าสู่ระบบ - วิธีการ


1

หากต้องการเพิ่มการยกเว้นสำหรับการล็อกแบ็กจาก Netbeans IDE

  1. เข้าไปที่ส่วน> Projects explorerสำหรับโปรเจ็กต์ของคุณ
  2. ดำเนินการต่อไปที่> การอ้างอิงตามที่แสดงด้านล่าง
  3. ติดตาม 'spring-boot-starter-logging-XXXjar'
  4. คลิกขวาที่ jar และเลือกExclude Dependencyดังที่แสดงด้านล่าง สิ่งนี้ไม่รวมโถการบันทึกกลับบน pom.xml เช่นนี้

      <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 ออกจากสปริงบูตตามที่กล่าวไว้ในคำตอบข้างต้นหรือลบ log4j ออกจากอูฐ

<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 ใน classpath ของคุณและเพิ่มการกำหนดค่าทั้งหมดของคุณโดยเพิ่มแอปเพนเดอร์รูท เมื่อ Spring boot เสร็จสิ้นการโหลด bean ก็จะเริ่มบันทึกตามการกำหนดค่าของคุณ

โดยการใช้ไซต์ของเรา หมายความว่าคุณได้อ่านและทำความเข้าใจนโยบายคุกกี้และนโยบายความเป็นส่วนตัวของเราแล้ว
Licensed under cc by-sa 3.0 with attribution required.