log4j - कॉन्फ़िगरेशन

पिछले अध्याय ने log4j के मुख्य घटकों को समझाया। यह अध्याय बताता है कि आप कॉन्फ़िगरेशन फ़ाइल का उपयोग करके मुख्य घटकों को कैसे कॉन्फ़िगर कर सकते हैं। Log4j को कॉन्फ़िगर करने में लेवल को असाइन करना, ऐपेंडर को परिभाषित करना और कॉन्फ़िगरेशन फाइल में लेआउट ऑब्जेक्ट्स को निर्दिष्ट करना शामिल है।

log4j.propertiesफ़ाइल एक log4j विन्यास फाइल है जो गुण-मान जोड़े में रखता है। डिफ़ॉल्ट रूप से, LogManager नाम की फ़ाइल के लिए दिखता हैlog4j.properties में CLASSPATH

  • रूट लकड़हारे के स्तर को परिभाषित किया गया है DEBUGDEBUG इसमें X नाम वाले एपेंडर को जोड़ दिया जाता है।

  • X नाम वाले ऐप्पल को एक वैध एपेंडर के रूप में सेट करें।

  • परिशिष्ट X के लिए लेआउट सेट करें।

log4j.properties सिंटैक्स:

निम्नलिखित एक X के लिए log4j.properties फ़ाइल का सिंटैक्स है :

# Define the root logger with appender X
log4j.rootLogger = DEBUG, X

# Set the appender named X to be a File appender
log4j.appender.X=org.apache.log4j.FileAppender

# Define the layout for X appender
log4j.appender.X.layout=org.apache.log4j.PatternLayout
log4j.appender.X.layout.conversionPattern=%m%n

log4j.properties उदाहरण

उपरोक्त सिंटैक्स का उपयोग करते हुए, हम निम्नलिखित को परिभाषित करते हैं log4j.properties फ़ाइल:

  • रूट लकड़हारे के स्तर को परिभाषित किया गया है DEBUG, DEBUG परिशिष्ट का नाम FILE यह करने के लिए।

  • उपाधीक्षक FILE की तरह परिभाषित किया गया है org.apache.log4j.FileAppender। यह नाम की एक फाइल को लिखता हैlog.out में स्थित log निर्देशिका।

  • परिभाषित किया गया लेआउट पैटर्न % m% n है , जिसका अर्थ है कि मुद्रित लॉगिंग संदेश के बाद एक नया वर्ण होगा।

# Define the root logger with appender file
log4j.rootLogger = DEBUG, 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

यह ध्यान रखना महत्वपूर्ण है कि log4j UNIX- शैली चर प्रतिस्थापन जैसे $ {variableName} का समर्थन करता है।

डिबग स्तर

हमने दोनों Appenders के साथ DEBUG का उपयोग किया है। सभी संभावित विकल्प हैं:

  • TRACE
  • DEBUG
  • INFO
  • WARN
  • ERROR
  • FATAL
  • ALL

इन स्तरों को बाद में इस ट्यूटोरियल में समझाया गया है।

Appenders

अपाचे log4j, एपेंडर ऑब्जेक्ट्स प्रदान करता है जो मुख्य रूप से कंसोल, फाइल्स, सॉकेट्स, NT इवेंट लॉग्स इत्यादि जैसे विभिन्न गंतव्यों के लिए लॉगिंग संदेशों को प्रिंट करने के लिए जिम्मेदार होते हैं।

प्रत्येक परिशिष्ट वस्तु में इसके साथ जुड़े अलग-अलग गुण होते हैं, और ये गुण उस वस्तु के व्यवहार को दर्शाते हैं।

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

हम निम्न विधि के साथ विन्यास फाइल में निम्नलिखित सेटिंग को शामिल करके एक लकड़हारे के लिए एक परिशिष्ट वस्तु जोड़ सकते हैं:

log4j.logger.[logger-name]=level, appender1,appender..n

आप XML प्रारूप में उसी विन्यास को इस प्रकार लिख सकते हैं:

<logger name="com.apress.logging.log4j" additivity="false">
   <appender-ref ref="appender1"/>
   <appender-ref ref="appender2"/>
</logger>

यदि आप अपने कार्यक्रम के अंदर परिशिष्ट वस्तु जोड़ने के इच्छुक हैं तो आप निम्नलिखित विधि का उपयोग कर सकते हैं:

public void addAppender(Appender appender);

AddAppender () विधि लकड़हारे वस्तु में एक परिशिष्ट जोड़ता है। जैसा कि उदाहरण कॉन्फ़िगरेशन प्रदर्शित करता है, कॉमा-से-अलग सूची में एक लकड़हारा के लिए कई ऐपेंडर ऑब्जेक्ट को जोड़ना संभव है, प्रत्येक मुद्रण लॉगिंग जानकारी को अलग-अलग गंतव्यों तक पहुंचाता है।

हमने अपने उदाहरण में केवल एक ऐप्पलेंडर फाइलएपेंडर का उपयोग किया है। सभी संभावित दावेदार विकल्प हैं:

  • AppenderSkeleton
  • AsyncAppender
  • ConsoleAppender
  • DailyRollingFileAppender
  • ExternallyRolledFileAppender
  • FileAppender
  • JDBCAppender
  • JMSAppender
  • LF5Appender
  • NTEventLogAppender
  • NullAppender
  • RollingFileAppender
  • SMTPAppender
  • SocketAppender
  • SocketHubAppender
  • SyslogAppender
  • TelnetAppender
  • WriterAppender

हम में FileAppender कवर करेगा लॉगिंग में फ़ाइलें और JDBC appender में शामिल किया जाएगा डाटाबेस में लॉग इन करना ।

ख़ाका

हमने अपने ऐपलेंडर के साथ पैटर्नलैट का इस्तेमाल किया है। सभी संभावित विकल्प हैं:

  • DateLayout
  • HTMLLayout
  • PatternLayout
  • SimpleLayout
  • XMLLayout

HTMLLayout और XMLLayout का उपयोग करके, आप HTML और XML प्रारूप में भी लॉग इन कर सकते हैं।

लेआउट स्वरूपण

आप अध्याय में एक लॉग संदेश को प्रारूपित करना सीखेंगे: लॉग स्वरूपण ।