स्प्रिंगबूट में लॉगबैक अक्षम करें


118

ऐसा प्रतीत होता है कि स्प्रिंगबूट ऑटोकॉन्फ़िगर खुद टॉमकोट के साथ लॉगबैक का उपयोग करने के लिए। मैं इसे अक्षम करना चाहता हूं और अपने कक्षापथ में जो मैं प्रदान करता हूं उसका उपयोग करता हूं।

नीचे त्रुटि संदेश।

LoggerFactory एक Logback LoggerContext नहीं है, लेकिन Logback Classpath पर है। या तो लॉगबैक हटा दें या प्रतियोगी कार्यान्वयन (वर्ग org.slf4j.impl.SimpleLoggerFactory) श्रेणी का उद्देश्य [org.slf4j.impl.SimpleLoggerFactory] वर्ग ch.qos.logback.classic.ogassicLontext का एक उदाहरण होना चाहिए

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

संघर्ष को हल करने के लिए स्प्रिंग-बूट-स्टार्टर और स्प्रिंग-बूट-स्टार्टर-वेब दोनों में बहिष्करण जोड़ें।

<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

1
क्या यह पता लगाने का एक तरीका है कि प्रत्येक जार में कुछ 'अन्वेषण' किए बिना कौन सा जार लॉगबैक घोषित करता है? और धन्यवाद! इससे मुझे मदद मिली
vivek_ganesan

4
mvn निर्भरता: पेड़ -Dverbose -Dincludes = स्प्रिंग-बूट-स्टार्टर-लॉगिंग
FOO

प्रत्येक वसंत-बूट-स्टार्टर में इस बहिष्करण को जोड़ने के लिए- * निर्भरता एक बड़ी परेशानी है। ऐसा लगता है कि ग्रैडल कम से कम एक वैश्विक बहिष्कार की अनुमति देता है। यह अकेले ही मुझे मावेन से स्विच करने पर विचार कर रहा है।
स्कॉटीसियस

59

ग्रेडल में एक बेहतर, अधिक सामान्य समाधान जोड़ने के लिए (सभी उदाहरणों को बाहर रखा जाएगा):

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

से https://docs.gradle.org/current/userguide/dependency_management.html


1
यह मेरे और कम से कम 7 अन्य लोगों के लिए काम करता है। मुझे नहीं लगता कि आपके कॉन्फ़िगरेशन या पर्यावरण के साथ कोई समस्या मेरे समाधान के लिए डाउनवोट होनी चाहिए (मुझे लगता है कि मुझे प्राप्त डाउनवोट आपकी टिप्पणी से था - यदि मैं गलत हूं तो माफी मांगता हूं)।
हांकका

1
अन्य सभी
विन्यास

यह काम नहीं करता है, मैं अभी भी देखता हूंspring-boot-starter-logging
एडम एरॉल्ड

40

ग्रेडेल में एक समाधान जोड़ने के लिए।

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मॉड्यूल को बाहर करने के लिए सभी आवश्यक है ।

इसे ग्रैडल बिल्ड फ़ाइल में जोड़ने से समस्या हल हो जाएगी:

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 में स्प्रिंग-बूट-स्टार्टर-टेस्ट का पता लगाएं और इसे इस प्रकार संशोधित करें:

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

इसके साथ मैं अभी भी अंतिम विरूपण साक्ष्य में लॉगबैक जार देख रहा था (बूट के मावेन प्लगइन के बजाय असेंबली प्लगइन का उपयोग कर रहा था - इसलिए यह सुनिश्चित नहीं है कि यह वास्तव में बूट पैकेजिंग के साथ काम करता है)
जनक बंदारा

7

यदि आप कहते हैं कि आपका पसंदीदा लकड़हारा वास्तव में क्या है, और आपने इसे स्थापित करने और इसे स्थापित करने के लिए क्या किया, तो यह मदद कर सकता है। वैसे भी, स्प्रिंग बूट क्लासपाथ में जो कुछ भी है उसके साथ काम करने की कोशिश करता है, इसलिए यदि आप लॉगबैक नहीं चाहते हैं, तो इसे क्लासपाथ से हटा दें। डॉक्स में log4j के लिए निर्देश हैं , लेकिन यही बात अन्य समर्थित लॉगिंग सिस्टम (कुछ भी slf4j, log4j या जावा उपयोग) पर लागू होगी।


3
मैं slf4j का उपयोग करता हूं और मैं अपने मावेन पोम फाइल में लॉगबैक नहीं देख सकता।
FOO

Logback है एक slf4j लकड़हारा। शायद आप अपने पोम को साझा कर सकते हैं?
डेव सीर

मैं किसी भी अन्य slf4j कार्यान्वयन को स्पष्ट रूप से नहीं देख सकता हूं, इसलिए यह परिवर्तनशील रूप से आना चाहिए। आप निर्भरता की कल्पना करने के लिए m2e (ग्रहण) या "mvan निर्भरता: वृक्ष" जैसे उपकरणों का उपयोग कर सकते हैं। ग्रहण टूलींग में निर्भरता को बाहर करने के लिए एक GUI भी है (जो कि आपको करने की आवश्यकता है - उनमें से एक को बाहर करें)। यह "स्प्रिंग-बूट-स्टार्टर-लॉगिंग" को बाहर करने के लिए पर्याप्त हो सकता है यदि आपके पास पहले से ही एक पूरा एसएलएफ 4 जे है (जेसीएल पुल सहित)।
डेव सीर

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

लेकिन यह मावेन उपयोगकर्ताओं के लिए काम नहीं करेगा । मेरी सभी निर्भरताएँ लिबास में थीं और मैं उन्हें अन्य फाइलों में नहीं चाहता था। तो यह समस्या हल हो गया था जोड़कर exclude module : 'spring-boot-starter-loggingमें spring-boot-starter-data-jpa,spring-boot-starter-test और व्यावहारिक रूप से बूट शब्द के साथ हर चीज में।

अपडेट करें

मेरा नया प्रोजेक्ट एक अद्यतन की जरूरत है, बाहर 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>

इसने वसंत-बूट-स्टार्टर-लॉगिंग को छोड़कर काम किया
प्रेटेक मेहता

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 का उपयोग करने का प्रयास कर रहे हैं, तो स्प्रिंगबूट में यह त्रुटि हुई है, तो इन चरणों को करें:

  • "इसे बाहर करके लॉग आउट करते समय जार निकालें" logejroupIds log4j-slf4j-impl / outeGroupIds "
  • पता लगाएँ कि कौन सी लाइब्रेरी "mvan dependecy: ट्री" कमांड का उपयोग करके "लॉगबैक-क्लासिक" पर निर्भर है
  • जहां कहीं भी आप इसे निर्भरता से बाहर पाते हैं।

यह त्रुटि इसलिए हुई क्योंकि लॉगबैक लॉग 4j2 परिवर्तनों को ओवरराइड करता है। SO यदि आप 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. > प्रोजेक्ट एक्सप्लोरर पर पहुंचेंअपनी परियोजना के लिए सेक्शन पर
  2. आगे बढ़ें> निर्भरताएँनीचे दिखाए गए अनुसार
  3. ट्रेस 'स्प्रिंग-बूट-स्टार्टर-लॉगिंग-एक्सएक्सएक्स'
  4. जार पर राइट क्लिक करें और नीचे दिखाए गए अनुसार बहिष्करण निर्भरता चुनें । यह इस तरह 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

इसका कारण यह है कि, स्प्रिंग बूट लॉगबैक के साथ अपने डिफ़ॉल्ट लॉग कॉन्फ़िगरेशन के रूप में आता है जबकि ऊंट लॉग 4 जे का उपयोग करता है। संघर्ष का कारण है। आपके पास दो विकल्प हैं, या तो स्प्रिंग बूट से लॉगबैक हटा दें जैसा कि ऊपर दिए गए उत्तर में है या ऊंट से लॉग 4 जे हटा दें।

<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

बस अपने classpath में logback.xml कॉन्फ़िगरेशन जोड़ें और जोड़ा रूट रूटेंडर के साथ अपने सभी कॉन्फ़िगरेशन जोड़ें। एक बार जब स्प्रिंग बूट बीन लोडिंग को पूरा कर लेता है, तो यह आपके कॉन्फ़िगरेशन के आधार पर लॉगिंग शुरू कर देगा।

हमारी साइट का प्रयोग करके, आप स्वीकार करते हैं कि आपने हमारी Cookie Policy और निजता नीति को पढ़ और समझा लिया है।
Licensed under cc by-sa 3.0 with attribution required.