SLF4J - त्रुटि संदेश

इस अध्याय में, हम SLF4J और उन संदेशों के कारणों / अर्थों के साथ काम करते समय मिलने वाली विभिन्न त्रुटि संदेशों या चेतावनी पर चर्चा करेंगे।

कक्षा को लोड करने में विफल "org.slf4j.impl.StaticLoggerBinder"।

यह एक चेतावनी है जो तब होती है जब कोई एसएलएफ 4 जे बाँधने के लिए नहीं होता है।

निम्नलिखित पूरी चेतावनी है -

SLF4J: Failed to load class "org.slf4j.impl.StaticLoggerBinder".
SLF4J: Defaulting to no-operation (NOP) logger implementation
SLF4J: See http://www.slf4j.org/codes.html#StaticLoggerBinder for further
details.

इसे हल करने के लिए, आपको लॉगिंग फ्रेमवर्क बाइंडिंग में से किसी एक को जोड़ना होगा। इसमें बताया गया हैHello world इस ट्यूटोरियल का अध्याय।

Note - यह SLF4J के संस्करणों में होता है जो 1.6.0 और 1.8.0-beta2 के बीच होता है।

कोई SLF4J प्रदाता नहीं मिले

Slf4j-1.8.0-beta2 में, उपरोक्त चेतावनी अधिक स्पष्ट है “No SLF4J providers were found”

निम्नलिखित पूरी चेतावनी है -

SLF4J: No SLF4J providers were found.
SLF4J: Defaulting to no-operation (NOP) logger implementation
SLF4J: See http://www.slf4j.org/codes.html#noProviders for further details.

Classpath में SLF4J बाइंडिंग शामिल है जो 1.8 से पहले slf4j-api संस्करणों को लक्षित करता है

यदि आप SLF4J 1.8 संस्करण का उपयोग कर रहे हैं और आपके पास क्लासपाथ में पिछले संस्करणों के बाइंडिंग हैं, लेकिन 1.8 के बाइंडिंग नहीं हैं, तो आपको एक चेतावनी दिखाई देगी जैसा कि नीचे दिखाया गया है।

SLF4J: No SLF4J providers were found.
SLF4J: Defaulting to no-operation (NOP) logger implementation
SLF4J: See http://www.slf4j.org/codes.html#noProviders for further details.
SLF4J: Class path contains SLF4J bindings targeting slf4j-api versions prior to
1.8.
SLF4J: Ignoring binding found at
[jar:file:/C:/Users/Tutorialspoint/Desktop/Latest%20Tutorials/SLF4J%20Tutorial/
slf4j-1.7.25/slf4j-jdk14-1.7.25.jar!/org/slf4j/impl/StaticLoggerBinder.class]
SLF4J: See http://www.slf4j.org/codes.html#ignoredBindings for an explanation.

NoClassDefFoundError: org / apache / commons / logging / LogFactory

अगर आप साथ काम कर रहे हैं slf4j-jcl और यदि आपके पास केवल slf4j-jcl.jar आपके क्लासपाथ में, आपको एक अपवाद मिलेगा जैसे नीचे दिया गया है।

Exception in thread "main" java.lang.NoClassDefFoundError:
org/apache/commons/logging/LogFactory
   at org.slf4j.impl.JCLLoggerFactory.getLogger(JCLLoggerFactory.java:77)
   at org.slf4j.LoggerFactory.getLogger(LoggerFactory.java:358)
   at SLF4JExample.main(SLF4JExample.java:8)
Caused by: java.lang.ClassNotFoundException:
org.apache.commons.logging.LogFactory
   at java.net.URLClassLoader.findClass(Unknown Source)
   at java.lang.ClassLoader.loadClass(Unknown Source)
   at sun.misc.Launcher$AppClassLoader.loadClass(Unknown Source)
   at java.lang.ClassLoader.loadClass(Unknown Source)
   ... 3 more

इसे हल करने के लिए, आपको जोड़ना होगा commons-logging.jar अपने सहपाठी को

पता चला दोनों jcl-over-slf4j.jar और बाउंड क्लास पर slf4j-jcl.jar बाउंड ।।

बाइंडिंग slf4j-jcl.jar JCL और करने के लिए slf4j लकड़हारा की पुनर्निर्देश कॉल jcl-over-slf4j.jarJCL लॉगर के कॉल को पुनर्निर्देशित करता है slf4j। इसलिए, आपके पास अपनी परियोजना के वर्गपथ में दोनों नहीं हो सकते। यदि आप ऐसा करते हैं, तो आपको एक अपवाद मिलेगा जैसे नीचे दिया गया है।

SLF4J: Detected both jcl-over-slf4j.jar AND bound slf4j-jcl.jar on the class
path, preempting StackOverflowError.
SLF4J: See also http://www.slf4j.org/codes.html#jclDelegationLoop for more
details.
Exception in thread "main" java.lang.ExceptionInInitializerError
   at org.slf4j.impl.StaticLoggerBinder.<init>(StaticLoggerBinder.java:71)
   at org.slf4j.impl.StaticLoggerBinder.<clinit>(StaticLoggerBinder.java:42)
   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 SLF4JExample.main(SLF4JExample.java:8)
Caused by: java.lang.IllegalStateException: Detected both jcl-over-slf4j.jar
AND bound slf4j-jcl.jar on the class path, preempting StackOverflowError. See
also http://www.slf4j.org/codes.html#jclDelegationLoop for more details.
   at org.slf4j.impl.JCLLoggerFactory.<clinit>(JCLLoggerFactory.java:54)
   ... 7 more

इसे हल करने के लिए, या तो जार फ़ाइलों को हटा दें।

पता लगाया लकड़हारा नाम बेमेल

आप एक लकड़हारा वस्तु बना सकते हैं -

  • तर्क के रूप में बनाए जाने के लिए लकड़हारे का नाम उत्तीर्ण करना getLogger() तरीका।

  • इस विधि के लिए एक तर्क के रूप में एक कक्षा पास करना।

यदि आप तर्क के रूप में एक वर्ग पास करके लकड़हारा कारखाना वस्तु बनाने की कोशिश कर रहे हैं, और यदि आपने सिस्टम गुण सेट किया है slf4j.detectLoggerNameMismatch यह सच है, तो उस वर्ग का नाम, जिसके पास आप तर्क के रूप में जाते हैं getLogger() विधि और आपके द्वारा उपयोग किया जाने वाला वर्ग समान होना चाहिए अन्यथा आपको निम्नलिखित चेतावनी प्राप्त होगी -

“पता लगाया लकड़हारा नाम बेमेल है।

निम्नलिखित उदाहरण पर विचार करें।

import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
public class SLF4JExample {
   public static void main(String[] args) {
      System.setProperty("slf4j.detectLoggerNameMismatch", "true");
      
      //Creating the Logger object
      Logger logger = LoggerFactory.getLogger(Sample.class);

      //Logging the information
      logger.info("Hi Welcome to Tutorilspoint");
   }
}

यहाँ, हमने slf4j.detectLoggerNameMismatch गुण को सही पर सेट किया है। जिस क्लास का हमने इस्तेमाल किया उसका नाम हैSLF4JExample और क्लास का नाम हमने गेटलॉगर () विधि से पास किया है Sample चूंकि वे दोनों समान नहीं हैं, इसलिए हमें निम्नलिखित चेतावनी मिलेगी।

SLF4J: Detected logger name mismatch. Given name: "Sample"; computed name:
"SLF4JExample".
SLF4J: See http://www.slf4j.org/codes.html#loggerNameMismatch for an
explanation
Dec 10, 2018 12:43:00 PM SLF4JExample main
INFO: Hi Welcome to Tutorilspoint

Note - यह slf4j 1.7.9 के बाद होता है

Classpath में कई SLF4J बाइंडिंग शामिल हैं।

आपको क्लासपाथ में केवल एक बंधन होना चाहिए। यदि आपके पास एक से अधिक बाइंडिंग है, तो आपको बाइंडिंग और उनके स्थानों को सूचीबद्ध करने की चेतावनी मिलेगी।

मान लीजिए, अगर हमारे पास बाइंडिंग है slf4j-jdk14.jar तथा slf4j-nop.jar क्लासपाथ में हमें निम्नलिखित चेतावनी मिलेगी।

SLF4J: Class path contains multiple SLF4J bindings.
SLF4J: Found binding in
[jar:file:/C:/Users/Tutorialspoint/Desktop/Latest%20Tutorials/SLF4J%20Tutorial/
slf4j-1.7.25/slf4j-nop-1.7.25.jar!/org/slf4j/impl/StaticLoggerBinder.class]
SLF4J: Found binding in
[jar:file:/C:/Users/Tutorialspoint/Desktop/Latest%20Tutorials/SLF4J%20Tutorial/
slf4j-1.7.25/slf4j-jdk14-1.7.25.jar!/org/slf4j/impl/StaticLoggerBinder.class]
SLF4J: See http://www.slf4j.org/codes.html#multiple_bindings for an
explanation.
SLF4J: Actual binding is of type [org.slf4j.helpers.NOPLoggerFactory]

वर्ग मार्ग पर log4j-over-slf4j.jar और बाउंड slf4j-log4j12.jar दोनों का पता लगाया

Log4j लकड़हारा कॉल को slf4j पर पुनर्निर्देशित करने के लिए, आपको उपयोग करने की आवश्यकता है log4j-over-slf4j.jar बाइंडिंग और यदि आप log4j पर slf4j कॉल पुनर्निर्देशित करना चाहते हैं, तो आपको उपयोग करने की आवश्यकता है slf4j-log4j12.jar बंधन।

इसलिए, आपके पास क्लासपाथ में दोनों नहीं हो सकते। यदि आप करते हैं, तो आपको निम्नलिखित अपवाद मिलेगा।

SLF4J: Detected both log4j-over-slf4j.jar AND bound slf4j-log4j12.jar on the
class path, preempting StackOverflowError.
SLF4J: See also http://www.slf4j.org/codes.html#log4jDelegationLoop for more
details.
Exception in thread "main" java.lang.ExceptionInInitializerError
   at org.slf4j.impl.StaticLoggerBinder.<init>(StaticLoggerBinder.java:72)
   at org.slf4j.impl.StaticLoggerBinder.<clinit>(StaticLoggerBinder.java:45)
   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.slf4j.LoggerFactory.getLogger(LoggerFactory.java:383)
   at SLF4JExample.main(SLF4JExample.java:8)
Caused by: java.lang.IllegalStateException: Detected both log4j-over-slf4j.jar
AND bound slf4j-log4j12.jar on the class path, preempting StackOverflowError.
See also http://www.slf4j.org/codes.html#log4jDelegationLoop for more details.