log4j - लॉगिंग स्तर
org.apache.log4j.Levelस्तरों। आप उप-वर्गीकृत करके अपने कस्टम स्तरों को भी परिभाषित कर सकते हैंLevel कक्षा।
स्तर | विवरण |
---|---|
सब | कस्टम स्तरों सहित सभी स्तर। |
डीबग | बारीक-बारीक सूचनात्मक घटनाओं को नामित करता है जो किसी एप्लिकेशन को डीबग करने के लिए सबसे उपयोगी होते हैं। |
जानकारी | सूचनात्मक संदेशों को नामित करता है जो मोटे अनाज वाले स्तर पर अनुप्रयोग की प्रगति को उजागर करते हैं। |
चेतावनी | संभावित रूप से हानिकारक स्थितियों को नामित करता है। |
त्रुटि | त्रुटि घटनाओं को नामित करता है जो अभी भी एप्लिकेशन को चालू रखने की अनुमति दे सकता है। |
घातक | बहुत गंभीर त्रुटि घटनाओं को नामित करता है जो संभवतः एप्लिकेशन को गर्भपात की ओर ले जाएगा। |
बंद | उच्चतम संभव रैंक और लॉगिंग को बंद करने का इरादा है। |
ट्रेस | DEBUG की तुलना में बारीक-बारीक सूचनात्मक घटनाओं को नामित करता है। |
कैसे काम करता है स्तर?
स्तर का एक लॉग अनुरोध p स्तर के साथ एक लकड़हारा में q है enabledअगर p> = q। यह नियम log4j के दिल में है। यह मानता है कि स्तरों का आदेश दिया गया है। मानक स्तरों के लिए, हमारे पास सभी <DEBUG <INFO <WARN <ERROR <FATAL <OFF है।
निम्नलिखित उदाहरण दिखाता है कि हम अपने सभी DEBUG और INFO संदेशों को कैसे फ़िल्टर कर सकते हैं। यह प्रोग्राम एक लॉगिंग स्तर सेट करने के लिए लकड़हारा विधि सेटलेवल (Level.X) का उपयोग करता है:
यह उदाहरण डिबग और जानकारी को छोड़कर सभी संदेशों को प्रिंट करेगा:
import org.apache.log4j.*;
public class LogClass {
private static org.apache.log4j.Logger log = Logger.getLogger(LogClass.class);
public static void main(String[] args) {
log.setLevel(Level.WARN);
log.trace("Trace Message!");
log.debug("Debug Message!");
log.info("Info Message!");
log.warn("Warn Message!");
log.error("Error Message!");
log.fatal("Fatal Message!");
}
}
जब आप संकलित करते हैं और चलाते हैं LogClass कार्यक्रम, यह निम्नलिखित परिणाम उत्पन्न करेगा -
Warn Message!
Error Message!
Fatal Message!
कॉन्फ़िगरेशन फ़ाइल का उपयोग करके स्तर सेट करना
log4j आपको कॉन्फ़िगरेशन फ़ाइल आधारित स्तर सेटिंग प्रदान करता है जो आपको डिबगिंग स्तर को बदलने के लिए स्रोत कोड को बदलने से मुक्त करता है।
निम्नलिखित एक उदाहरण कॉन्फ़िगरेशन फ़ाइल है जो उसी कार्य को करेगी जैसा हमने प्रयोग किया था log.setLevel(Level.WARN) उपरोक्त उदाहरण में विधि।
# Define the root logger with appender file
log = /usr/home/log4j
log4j.rootLogger = WARN, FILE
# Define the file appender
log4j.appender.FILE=org.apache.log4j.FileAppender
log4j.appender.FILE.File=${log}/log.out
# Define the layout for file appender
log4j.appender.FILE.layout=org.apache.log4j.PatternLayout
log4j.appender.FILE.layout.conversionPattern=%m%n
आइये अब हम अपने निम्नलिखित कार्यक्रम का उपयोग करते हैं -
import org.apache.log4j.*;
public class LogClass {
private static org.apache.log4j.Logger log = Logger.getLogger(LogClass.class);
public static void main(String[] args) {
log.trace("Trace Message!");
log.debug("Debug Message!");
log.info("Info Message!");
log.warn("Warn Message!");
log.error("Error Message!");
log.fatal("Fatal Message!");
}
}
अब उपरोक्त प्रोग्राम को संकलित करें और चलाएं और आपको निम्नलिखित परिणाम प्राप्त होंगे /usr/home/log4j/log.out फ़ाइल -
Warn Message!
Error Message!
Fatal Message!