log4j - त्वरित गाइड

log4j जावा में लिखा गया एक विश्वसनीय, तेज और लचीला लॉगिंग फ्रेमवर्क (एपीआई) है, जो अपाचे सॉफ्टवेयर लाइसेंस के तहत वितरित किया जाता है।

log4j को C, C ++, C #, Perl, Python, Ruby और Eiffel भाषाओं में पोर्ट किया गया है।

log4j रनटाइम पर बाहरी कॉन्फ़िगरेशन फ़ाइलों के माध्यम से अत्यधिक विन्यास योग्य है। यह प्राथमिकताओं के स्तरों के संदर्भ में लॉगिंग प्रक्रिया को देखता है और लॉगिंग जानकारी को कई प्रकार के गंतव्यों, जैसे डेटाबेस, फ़ाइल, कंसोल, UNIX Syslog, आदि के लिए निर्देशित करने के लिए तंत्र प्रदान करता है।

log4j के तीन मुख्य घटक हैं:

  • loggers: लॉगिंग जानकारी कैप्चर करने के लिए जिम्मेदार।

  • appenders: विभिन्न पसंदीदा स्थलों के लिए लॉगिंग जानकारी प्रकाशित करने के लिए जिम्मेदार।

  • layouts: विभिन्न शैलियों में लॉगिंग जानकारी को स्वरूपित करने के लिए जिम्मेदार।

Log4j का इतिहास

  • यूरोपीय संघ सेमर (यूरोप के लिए सुरक्षित इलेक्ट्रॉनिक बाज़ार) परियोजना के लिए अनुरेखण एपीआई के रूप में 1996 की शुरुआत में शुरू किया।

  • अनगिनत एन्हांसमेंट्स और कई अवतारों के बाद, प्रारंभिक एपीआई log4j बनने के लिए विकसित हुआ है, जो जावा के लिए एक लोकप्रिय लॉगिंग पैकेज है।

  • पैकेज को अपाचे सॉफ्टवेयर लाइसेंस के तहत वितरित किया जाता है, जो पूर्ण स्रोत ओपन सोर्स लाइसेंस है जिसे ओपन सोर्स पहल द्वारा प्रमाणित किया गया है।

  • इसके पूर्ण-स्रोत कोड, वर्ग फ़ाइलों और दस्तावेज़ीकरण सहित नवीनतम log4j संस्करण पाया जा सकता है http://logging.apache.org/log4j/।

log4j सुविधाएँ

  • यह धागा-सुरक्षित है।

  • यह गति के लिए अनुकूलित है।

  • यह एक नामित लकड़हारा पदानुक्रम पर आधारित है।

  • यह प्रति लकड़हारा कई आउटपुट एपेंडरों का समर्थन करता है।

  • यह अंतर्राष्ट्रीयकरण का समर्थन करता है।

  • यह सुविधाओं के पूर्वनिर्धारित सेट तक सीमित नहीं है।

  • लॉगिंग व्यवहार को कॉन्फ़िगरेशन फ़ाइल का उपयोग करके रनटाइम पर सेट किया जा सकता है।

  • यह जावा एक्सेप्शन को शुरू से संभालने के लिए बनाया गया है।

  • यह कई स्तरों, अर्थात्, TRACE, DEBUG, INFO, WARN, ERROR और FATAL का उपयोग करता है।

  • लेआउट क्लास का विस्तार करके लॉग आउटपुट के प्रारूप को आसानी से बदला जा सकता है ।

  • लॉग आउटपुट के लक्ष्य के साथ-साथ लेखन रणनीति को एपेंडर इंटरफेस के कार्यान्वयन से बदल दिया जा सकता है।

  • यह फेल-स्टॉप है। हालाँकि, हालांकि यह निश्चित रूप से वितरण सुनिश्चित करने के लिए प्रयास करता है, log4j यह गारंटी नहीं देता है कि प्रत्येक लॉग स्टेटमेंट को उसके गंतव्य तक पहुंचाया जाएगा।

पेशेवरों और लॉगिंग के विपक्ष

लॉगिंग सॉफ्टवेयर विकास का एक महत्वपूर्ण घटक है। एक अच्छी तरह से लिखा लॉगिंग कोड त्वरित डिबगिंग, आसान रखरखाव और एक एप्लिकेशन के रनटाइम जानकारी के संरचित भंडारण प्रदान करता है।

लॉगिंग में इसकी कमियां भी हैं। यह किसी एप्लिकेशन को धीमा कर सकता है। यदि बहुत अधिक क्रिया है, तो यह स्क्रॉलिंग ब्लाइंडनेस का कारण बन सकता है। इन चिंताओं को कम करने के लिए, log4j को विश्वसनीय, तेज और एक्स्टेंसिबल बनाया गया है।

चूंकि लॉगिंग शायद ही कभी किसी एप्लिकेशन का मुख्य फोकस होता है, लॉग 4j एपीआई समझने और उपयोग करने में सरल होने का प्रयास करता है।

log4j एपीआई पैकेज को अपाचे सॉफ्टवेयर लाइसेंस के तहत वितरित किया जाता है, जो पूर्ण स्रोत ओपन सोर्स लाइसेंस है जिसे ओपन सोर्स पहल द्वारा प्रमाणित किया गया है।

नवीनतम लॉग 4j संस्करण, जिसमें पूर्ण-स्रोत कोड, क्लास फाइलें और प्रलेखन शामिल हैं, पर पाया जा सकता है http://logging.apache.org/log4j/।

अपने सिस्टम पर log4j स्थापित करने के लिए, अपाचे- log4j-xxxtar.gz को निर्दिष्ट URL से डाउनलोड करें और नीचे दिए गए चरणों का पालन करें।

चरण 1

निम्न फ़ाइल को / usr / स्थानीय / निर्देशिका में डाउनलोड की गई फ़ाइल को खोलना और खोलना

$ gunzip apache-log4j-1.2.15.tar.gz
$ tar -xvf apache-log4j-1.2.15.tar
apache-log4j-1.2.15/tests/input/
apache-log4j-1.2.15/tests/input/xml/
apache-log4j-1.2.15/tests/src/
apache-log4j-1.2.15/tests/src/java/
apache-log4j-1.2.15/tests/src/java/org/
.......................................

अनियंत्रित रहते हुए, यह एक अपाचे-लॉग 4 जे-एक्सएक्सएक्स नाम के साथ एक निर्देशिका पदानुक्रम बनाएगा:

-rw-r--r--  1 root root   3565 2007-08-25 00:09 BUILD-INFO.txt
-rw-r--r--  1 root root   2607 2007-08-25 00:09 build.properties.sample
-rw-r--r--  1 root root  32619 2007-08-25 00:09 build.xml
drwxr-xr-x 14 root root   4096 2010-02-04 14:09 contribs
drwxr-xr-x  5 root root   4096 2010-02-04 14:09 examples
-rw-r--r--  1 root root   2752 2007-08-25 00:09 INSTALL
-rw-r--r--  1 root root   4787 2007-08-25 00:09 KEYS
-rw-r--r--  1 root root  11366 2007-08-25 00:09 LICENSE
-rw-r--r--  1 root root 391834 2007-08-25 00:29 log4j-1.2.15.jar
-rw-r--r--  1 root root    160 2007-08-25 00:09 NOTICE
-rwxr-xr-x  1 root root  10240 2007-08-25 00:27 NTEventLogAppender.dll
-rw-r--r--  1 root root  17780 2007-08-25 00:09 pom.xml
drwxr-xr-x  7 root root   4096 2007-08-25 00:13 site
drwxr-xr-x  8 root root   4096 2010-02-04 14:08 src
drwxr-xr-x  6 root root   4096 2010-02-04 14:09 tests

चरण 2

यह चरण वैकल्पिक है और इस बात पर निर्भर करता है कि आप log4j फ्रेमवर्क से किन विशेषताओं का उपयोग करने जा रहे हैं। यदि आपके पास पहले से ही आपके मशीन पर निम्नलिखित पैकेज स्थापित हैं तो यह ठीक है, अन्यथा आपको लॉग 4 जे काम करने के लिए उन्हें स्थापित करने की आवश्यकता है।

  • JavaMail API:ई-मेल आधारित log4j में प्रवेश सुविधा जावा मेल एपीआई (mail.jar) से अपने मशीन पर स्थापित करने की आवश्यकता है glassfish.dev ।

  • JavaBeans Activation Framework: जावा मेल एपीआई के लिए यह भी आवश्यक होगा कि आपकी मशीन पर JavaBeans एक्टिवेशन फ्रेमवर्क (सक्रियण .jar) स्थापित किया जाए http://java.sun.com/products/javabeans/jaf/index.jsp।

  • Java Message Service: Log4j के JMS- संगत विशेषताओं के लिए आवश्यक है कि JMS और Java नामकरण और निर्देशिका इंटरफ़ेस JNDI दोनों को आपकी मशीन पर स्थापित किया जाए http://java.sun.com/products/jms।

  • XML Parser:Log4j का उपयोग करने के लिए आपको JAXP- संगत XML पार्सर की आवश्यकता है। सुनिश्चित करें कि आपके पास अपनी मशीन पर Xerces.jar स्थापित हैhttp://xerces.apache.org/xerces-j/install.html।

चरण 3

अब आपको सेट अप करने की आवश्यकता है CLASSPATH तथा PATHचर उचित रूप से। यहां हम इसे log4j.xxxjar फ़ाइल के लिए सेट करने जा रहे हैं।

$ pwd
/usr/local/apache-log4j-1.2.15
$ export CLASSPATH= \
      $CLASSPATH:/usr/local/apache-log4j-1.2.15/log4j-1.2.15.jar
$ export PATH=$PATH:/usr/local/apache-log4j-1.2.15/

log4j एपीआई एक स्तरित वास्तुकला का अनुसरण करता है जहां प्रत्येक परत विभिन्न कार्यों को करने के लिए अलग-अलग वस्तुएं प्रदान करती है। यह स्तरित वास्तुकला डिजाइन को लचीला और भविष्य में विस्तारित करने में आसान बनाता है।

Log4j ढांचे के साथ दो प्रकार की वस्तुएं उपलब्ध हैं।

  • Core Objects:ये ढांचे की अनिवार्य वस्तुएं हैं। उन्हें रूपरेखा का उपयोग करना आवश्यक है।

  • Support Objects:ये फ्रेमवर्क की वैकल्पिक वस्तुएं हैं। वे अतिरिक्त लेकिन महत्वपूर्ण कार्यों को करने के लिए मुख्य वस्तुओं का समर्थन करते हैं।

कोर ऑब्जेक्ट्स

मुख्य वस्तुओं में निम्नलिखित प्रकार की वस्तुएँ शामिल हैं:

लकड़हारा वस्तु

शीर्ष-स्तरीय परत लकड़हारा है जो लकड़हारा वस्तु प्रदान करता है। लॉगर ऑब्जेक्ट लॉगिंग जानकारी को कैप्चर करने के लिए जिम्मेदार है और वे एक नेमस्पेस पदानुक्रम में संग्रहीत हैं।

लेआउट वस्तु

लेआउट परत उन वस्तुओं को प्रदान करती है जो विभिन्न शैलियों में लॉगिंग जानकारी को प्रारूपित करने के लिए उपयोग की जाती हैं। यह लॉगिंग जानकारी को प्रकाशित करने से पहले परिशिष्ट वस्तुओं को सहायता प्रदान करता है।

लॉगिंग जानकारी को इस तरह से प्रकाशित करने में लेआउट ऑब्जेक्ट एक महत्वपूर्ण भूमिका निभाते हैं जो मानव-पठनीय और पुन: प्रयोज्य है।

परिशिष्ट वस्तु

यह एक निचले स्तर की परत है जो परिशिष्ट वस्तुएं प्रदान करती है। Appender ऑब्जेक्ट विभिन्न पसंदीदा गंतव्यों जैसे डेटाबेस, फ़ाइल, कंसोल, UNIX Syslog, आदि के लिए लॉगिंग जानकारी प्रकाशित करने के लिए ज़िम्मेदार है।

निम्नलिखित वर्चुअल आरेख log4J ढांचे के घटकों को दर्शाता है:

समर्थन वस्तुओं

Log4j फ्रेमवर्क में अन्य महत्वपूर्ण वस्तुएं हैं जो लॉगिंग फ्रेमवर्क में महत्वपूर्ण भूमिका निभाती हैं:

स्तर की वस्तु

लेवल ऑब्जेक्ट किसी भी लॉगिंग जानकारी की ग्रैन्युलैरिटी और प्राथमिकता को परिभाषित करता है। API के भीतर लॉगिंग के सात स्तर परिभाषित हैं: OFF, DEBUG, INFO, ERROR, WARN, FATAL, और ALL।

फ़िल्टर वस्तु

फ़िल्टर ऑब्जेक्ट का उपयोग लॉगिंग जानकारी का विश्लेषण करने और उस जानकारी को लॉग इन किया जाना चाहिए या नहीं इस पर आगे निर्णय लेने के लिए किया जाता है।

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

ObjectRenderer

ObjectRenderer ऑब्जेक्ट लॉगिंग ढांचे में पारित विभिन्न वस्तुओं के स्ट्रिंग प्रतिनिधित्व प्रदान करने में विशिष्ट है। इस ऑब्जेक्ट का उपयोग लेआउट ऑब्जेक्ट द्वारा अंतिम लॉगिंग जानकारी तैयार करने के लिए किया जाता है।

LogManager

LogManager ऑब्जेक्ट लॉगिंग ढांचे का प्रबंधन करता है। यह सिस्टम-वाइड कॉन्फ़िगरेशन फ़ाइल या कॉन्फ़िगरेशन क्लास से प्रारंभिक कॉन्फ़िगरेशन पैरामीटर पढ़ने के लिए ज़िम्मेदार है।

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

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

  • रूट लॉगर का स्तर DEBUG के रूप में परिभाषित किया गया है। DEBUG, 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

इन स्तरों को log4j लॉगिंग स्तरों में समझाया जाएगा ।

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 प्रारूप में भी लॉग इन कर सकते हैं।

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

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

हमने देखा है कि विन्यास फाइल कैसे बनाते हैं। यह अध्याय डिबग संदेश उत्पन्न करने और उन्हें एक साधारण पाठ फ़ाइल में लॉग इन करने का वर्णन करता है।

निम्नलिखित हमारे उदाहरण के लिए बनाई गई एक सरल कॉन्फ़िगरेशन फ़ाइल है। आइए हम इसे एक बार फिर से संशोधित करते हैं:

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

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

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

Log4j.properties फ़ाइल की सामग्री इस प्रकार है:

# Define the root logger with appender file
log = /usr/home/log4j
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

Java प्रोग्राम में log4j का उपयोग करना

निम्न जावा वर्ग एक बहुत ही सरल उदाहरण है जो आरंभ करता है, और फिर जावा अनुप्रयोगों के लिए Log4J लॉगिंग लाइब्रेरी का उपयोग करता है।

import org.apache.log4j.Logger;

import java.io.*;
import java.sql.SQLException;
import java.util.*;

public class log4jExample{
   /* Get actual class name to be printed on */
   static Logger log = Logger.getLogger(log4jExample.class.getName());
   
   public static void main(String[] args)throws IOException,SQLException{
      log.debug("Hello this is a debug message");
      log.info("Hello this is an info message");
   }
}

संकलन और निष्पादन

उपर्युक्त कार्यक्रम को संकलित करने और चलाने के लिए यहां चरण दिए गए हैं। सुनिश्चित करें कि आपने सेट किया हैPATH तथा CLASSPATH संकलन और निष्पादन के लिए आगे बढ़ने से पहले उचित रूप से।

सभी पुस्तकालयों में उपलब्ध होना चाहिए CLASSPATHऔर आपकी log4j.properties फ़ाइल पथ में उपलब्ध होनी चाहिए। नीचे दिए गए चरणों का पालन करें:

  • जैसा कि ऊपर दिखाया गया है log4j.properties बनाएँ।

  • जैसा कि ऊपर दिखाया गया है log4jExample.java बनाएं और इसे संकलित करें।

  • प्रोग्राम को चलाने के लिए log4jExample बाइनरी निष्पादित करें।

आपको निम्नलिखित परिणाम /usr/home/log4j/log.out फ़ाइल के लिए मिलेगा:

Hello this is a debug message
Hello this is an info message

लकड़हारा वर्ग लॉगिंग गतिविधियों को संभालने के लिए कई तरह के तरीके प्रदान करता है। लकड़हारा वर्ग हमें एक नया लकड़हारा उदाहरण के लिए तुरंत अनुमति नहीं देता है, लेकिन यह एक लकड़हारा वस्तु प्राप्त करने के लिए दो स्थिर तरीके प्रदान करता है:

  • public static Logger getRootLogger();
  • public static Logger getLogger(String name);

दो विधियों में से पहला एप्लिकेशन इंस्टेंस के रूट लॉगर को लौटाता है और इसका कोई नाम नहीं है।

लकड़हारा वस्तु का नाम किसी भी अन्य लकड़हारे के नाम से गुजरकर दूसरी विधि के माध्यम से प्राप्त होता है। लकड़हारा का नाम किसी भी तार से हो सकता है जिसे आप पास कर सकते हैं, आमतौर पर एक वर्ग या पैकेज का नाम जैसा कि हमने पिछले अध्याय में इस्तेमाल किया है और यह नीचे दिया गया है:

static Logger log = Logger.getLogger(log4jExample.class.getName());

लॉगिंग के तरीके

एक बार जब हम एक नामित लकड़हारा का एक उदाहरण प्राप्त करते हैं, तो हम संदेश लॉग करने के लिए लकड़हारे के कई तरीकों का उपयोग कर सकते हैं। लॉगिंग जानकारी को प्रिंट करने के लिए लॉगर वर्ग में निम्न विधियाँ हैं।

अनु क्रमांक तरीके और विवरण
1 public void debug(Object message)

यह संदेशों को स्तर Level.DEBUG के साथ प्रिंट करता है।

2 public void error(Object message)

यह संदेश को Level.ERROR के स्तर के साथ प्रिंट करता है।

3 public void fatal(Object message);

यह संदेश को Level Level.ATAL के साथ प्रिंट करता है।

4 public void info(Object message);

यह स्तर Level.INFO के साथ संदेश प्रिंट करता है।

5 public void warn(Object message);

यह संदेश को स्तर Level.ARN के साथ प्रिंट करता है।

6 public void trace(Object message);

यह संदेश को Level.TRACE के साथ प्रिंट करता है।

सभी स्तर org.apache.log4j.Level श्रेणी में परिभाषित किए गए हैं और उपर्युक्त तरीकों में से कोई भी निम्नानुसार हो सकता है:

import org.apache.log4j.Logger;

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!");
   }
}

जब आप LogClass प्रोग्राम को संकलित और चलाते हैं, तो यह निम्नलिखित परिणाम उत्पन्न करेगा:

Debug Message!
Info Message!
Warn Message!
Error Message!
Fatal Message!

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

Org.apache.log4j.evel वर्ग निम्नलिखित स्तर प्रदान करता है। आप स्तर वर्ग को उप-वर्ग करके अपने कस्टम स्तरों को भी परिभाषित कर सकते हैं।

स्तर विवरण
सब कस्टम स्तरों सहित सभी स्तर।
डीबग बारीक-बारीक सूचनात्मक घटनाओं को नामित करता है जो किसी एप्लिकेशन को डीबग करने के लिए सबसे उपयोगी होते हैं।
जानकारी सूचनात्मक संदेशों को नामित करता है जो मोटे अनाज वाले स्तर पर अनुप्रयोग की प्रगति को उजागर करते हैं।
चेतावनी संभावित रूप से हानिकारक स्थितियों को नामित करता है।
त्रुटि त्रुटि घटनाओं को नामित करता है जो अभी भी एप्लिकेशन को चालू रखने की अनुमति दे सकता है।
घातक बहुत गंभीर त्रुटि घटनाओं को नामित करता है जो संभवतः एप्लिकेशन को गर्भपात की ओर ले जाएगा।
बंद उच्चतम संभव रैंक और लॉगिंग को बंद करने का इरादा है।
ट्रेस DEBUG की तुलना में बारीक-बारीक सूचनात्मक घटनाओं को नामित करता है।

कैसे काम करता है स्तर?

स्तर का एक लॉग अनुरोध p स्तर के साथ एक लकड़हारा में qयदि 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!

Apache log4j विभिन्न लेआउट ऑब्जेक्ट प्रदान करता है, जिनमें से प्रत्येक विभिन्न लेआउट के अनुसार लॉगिंग डेटा को प्रारूपित कर सकता है। एक लेआउट ऑब्जेक्ट बनाना भी संभव है जो डेटा को एप्लिकेशन-विशिष्ट तरीके से लॉगिंग करता है।

सभी लेआउट ऑब्जेक्ट्स को Appender ऑब्जेक्ट्स से LoggingEvent ऑब्जेक्ट प्राप्त होता है। लेआउट ऑब्जेक्ट तब लॉगिंगइवेंट से संदेश तर्क को पुनः प्राप्त करते हैं और संदेश के स्ट्रिंग प्रतिनिधित्व को प्राप्त करने के लिए उपयुक्त ऑब्जेक्टरेंडर लागू करते हैं।

लेआउट प्रकार

पदानुक्रम में शीर्ष-स्तरीय वर्ग सार वर्ग है। org.apache.log4j.Layout। यह log4j एपीआई में अन्य सभी लेआउट वर्गों के लिए आधार वर्ग है।

लेआउट वर्ग को एक अनुप्रयोग के भीतर सार के रूप में परिभाषित किया गया है, हम कभी भी सीधे इस वर्ग का उपयोग नहीं करते हैं; इसके बजाय, हम इसके उपवर्गों के साथ काम करते हैं जो इस प्रकार हैं:

  • DateLayout

  • HTMLLayout

  • PatternLayout.

  • SimpleLayout

  • XMLLayout

लेआउट के तरीके

यह वर्ग अन्य सभी लेआउट ऑब्जेक्ट्स में सभी सामान्य ऑपरेशनों का एक कंकाल कार्यान्वयन प्रदान करता है और दो सार विधियों की घोषणा करता है।

अनु क्रमांक। तरीके और विवरण
1 public abstract boolean ignoresThrowable()

यह इंगित करता है कि लॉगिंग जानकारी किसी भी java.lang को संभालती है। लॉग करने की घटना के एक हिस्से के रूप में यह पारित होने योग्य ऑब्जेक्ट। यदि लेआउट ऑब्जेक्ट थ्रॉएबल ऑब्जेक्ट को हैंडल करता है, तो लेआउट ऑब्जेक्ट इसे अनदेखा नहीं करता है, और गलत रिटर्न देता है।

2 public abstract String format(LoggingEvent event)

व्यक्तिगत लेआउट उपवर्ग लेआउट विशिष्ट स्वरूपण के लिए इस पद्धति को लागू करते हैं।

इन सार विधियों के अलावा, लेआउट वर्ग नीचे सूचीबद्ध तरीकों के लिए ठोस कार्यान्वयन प्रदान करता है:

अनु क्रमांक। तरीके और विवरण
1 public String getContentType()

यह लेआउट ऑब्जेक्ट्स द्वारा उपयोग की जाने वाली सामग्री प्रकार देता है। आधार वर्ग डिफ़ॉल्ट सामग्री प्रकार के रूप में पाठ / सादा देता है।

2 public String getFooter()

यह लॉगिंग संदेश के पाद सूचना को निर्दिष्ट करता है।

3 public String getHeader()

यह लॉगिंग संदेश की हेडर जानकारी को निर्दिष्ट करता है।

प्रत्येक उपवर्ग इन विधियों के ठोस कार्यान्वयन को ओवरराइड करके वर्ग-विशिष्ट जानकारी लौटा सकता है।

अपनी लॉगिंग जानकारी को एक फ़ाइल में लिखने के लिए, आपको org.apache.log4j.FileAppender का उपयोग करना होगा ।

FileAppender कॉन्फ़िगरेशन

FileAppender में निम्नलिखित विन्यास पैरामीटर हैं:

संपत्ति विवरण
immediateFlush यह ध्वज डिफ़ॉल्ट रूप से सही पर सेट है, जिसका अर्थ है कि प्रत्येक स्ट्रीम ऑपरेशन के साथ फाइल को आउटपुट स्ट्रीम को फ्लश किया जा रहा है।
एन्कोडिंग किसी भी वर्ण-एन्कोडिंग का उपयोग करना संभव है। डिफ़ॉल्ट रूप से, यह प्लेटफ़ॉर्म-विशिष्ट एन्कोडिंग योजना है।
द्वार इस परिशिष्ट के लिए सीमा स्तर।
फ़ाइल का नाम लॉग फ़ाइल का नाम।
fileAppend यह डिफ़ॉल्ट रूप से सत्य पर सेट है, जिसका अर्थ है कि लॉगिंग जानकारी को उसी फ़ाइल के अंत में जोड़ा जा रहा है।
bufferedIO यह ध्वज इंगित करता है कि क्या हमें बफरिंग सक्षम करने की आवश्यकता है। डिफ़ॉल्ट रूप से, यह गलत पर सेट होता है।
बफर आकार यदि बफ़र किया गया I / O सक्षम है, तो यह बफ़र आकार इंगित करता है। डिफ़ॉल्ट रूप से, यह 8kb पर सेट होता है।

फाइलएपेंडर के लिए एक नमूना विन्यास फाइल log4j.properties निम्नलिखित है।

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

# Define the file appender
log4j.appender.FILE=org.apache.log4j.FileAppender

# Set the name of the file
log4j.appender.FILE.File=${log}/log.out

# Set the immediate flush to true (default)
log4j.appender.FILE.ImmediateFlush=true

# Set the threshold to debug mode
log4j.appender.FILE.Threshold=debug

# Set the append to false, overwrite
log4j.appender.FILE.Append=false

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

यदि आप XML लॉग फ़ाइल को उपरोक्त log4j.properties फ़ाइल के बराबर चाहते हैं , तो यहाँ सामग्री है:

<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE log4j:configuration SYSTEM "log4j.dtd">
<log4j:configuration>

<appender name="FILE" class="org.apache.log4j.FileAppender">
   <param name="file" value="${log}/log.out"/>
   <param name="immediateFlush" value="true"/>
   <param name="threshold" value="debug"/>
   <param name="append" value="false"/>
   <layout class="org.apache.log4j.PatternLayout">
      <param name="conversionPattern" value="%m%n"/>
   </layout>
</appender>

<logger name="log4j.rootLogger" additivity="false">
   <level value="DEBUG"/>
   <appender-ref ref="FILE"/>
</logger>

</log4j:configuration>

आप उपरोक्त विन्यास के साथ log4j - नमूना कार्यक्रम का प्रयास कर सकते हैं ।

एकाधिक फ़ाइलों में लॉगिंग

आप कुछ कारणों से अपने लॉग संदेशों को कई फ़ाइलों में लिखना चाहते हैं, उदाहरण के लिए, यदि फ़ाइल का आकार एक निश्चित सीमा तक पहुंच गया है।

एकाधिक फ़ाइलों में अपने प्रवेश जानकारी लिखने के लिए, आप का उपयोग करना होगा org.apache.log4j.RollingFileAppender वर्ग जो फैली FileAppender वर्ग और inherits सब उसके गुण।

फ़ाइलएपेंडर के लिए ऊपर उल्लिखित के अलावा हमारे पास निम्नलिखित विन्यास योग्य पैरामीटर हैं:

संपत्ति विवरण
maxFileSize यह फ़ाइल का महत्वपूर्ण आकार है जिसके ऊपर फ़ाइल को रोल किया जाएगा। डिफ़ॉल्ट मान 10 एमबी है।
maxBackupIndex यह प्रॉपर्टी बनाई जाने वाली बैकअप फ़ाइलों की संख्या को दर्शाता है। डिफ़ॉल्ट मान 1 है।

निम्नलिखित RollingFileAppender के लिए एक नमूना कॉन्फ़िगरेशन फ़ाइल log4j.properties है।

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

# Define the file appender
log4j.appender.FILE=org.apache.log4j.RollingFileAppender

# Set the name of the file
log4j.appender.FILE.File=${log}/log.out

# Set the immediate flush to true (default)
log4j.appender.FILE.ImmediateFlush=true

# Set the threshold to debug mode
log4j.appender.FILE.Threshold=debug

# Set the append to false, should not overwrite
log4j.appender.FILE.Append=true

# Set the maximum file size before rollover
log4j.appender.FILE.MaxFileSize=5MB

# Set the the backup index
log4j.appender.FILE.MaxBackupIndex=2

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

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

यह उदाहरण कॉन्फ़िगरेशन दर्शाता है कि प्रत्येक लॉग फ़ाइल का अधिकतम स्वीकार्य आकार 5 एमबी है। अधिकतम आकार से अधिक होने पर, एक नई लॉग फ़ाइल बनाई जाएगी। चूंकि maxBackupIndex को 2 के रूप में परिभाषित किया गया है, एक बार जब दूसरी लॉग फ़ाइल अधिकतम आकार तक पहुँच जाती है, तो पहली लॉग फ़ाइल मिट जाएगी और उसके बाद, लॉगिंग की सभी जानकारी पहले लॉग फ़ाइल में वापस आ जाएगी।

आप उपरोक्त विन्यास के साथ log4j - नमूना कार्यक्रम का प्रयास कर सकते हैं ।

दैनिक लॉग फ़ाइल पीढ़ी

आपकी लॉगिंग जानकारी का एक साफ रिकॉर्ड रखने के लिए दैनिक आधार पर आपकी लॉग फाइल उत्पन्न करने की आवश्यकता हो सकती है।

एक दैनिक आधार पर फ़ाइलों में अपने प्रवेश जानकारी लिखने के लिए, आप का उपयोग करना होगा org.apache.log4j.DailyRollingFileAppender वर्ग जो फैली FileAppender वर्ग और inherits सब उसके गुण।

FileAppender के लिए ऊपर वर्णित के अलावा केवल एक महत्वपूर्ण विन्यास योग्य पैरामीटर है:

संपत्ति विवरण
DatePattern यह इंगित करता है कि फ़ाइल पर कब रोल करना है और नामकरण सम्मेलन का पालन करना है। डिफ़ॉल्ट रूप से, रोल ओवर प्रत्येक दिन आधी रात को किया जाता है।

DatePattern निम्नलिखित पैटर्न में से एक का उपयोग करके रोलओवर शेड्यूल को नियंत्रित करता है:

DatePattern विवरण
'।' yyyy-MM प्रत्येक महीने के अंत में और अगले महीने की शुरुआत में रोल ओवर करें।
'।' yyyy-MM-dd प्रत्येक दिन आधी रात को रोल करें। यह व्यतिक्रम मूल्य है।
'।' yyyy-MM-dd-एक प्रत्येक दिन दोपहर और आधी रात को रोल करें।
'।' yyyy-MM-dd-एचएच हर घंटे के शीर्ष पर रोल करें।
'।' yyyy-MM-dd-HH-मिमी हर मिनट पर रोल करें।
'।' yyyy-ww लोकेल के आधार पर प्रत्येक सप्ताह के पहले दिन रोल करें।

निम्नलिखित एक नमूना विन्यास फाइल है log4j.properties प्रत्येक दिन के मध्यरात्रि और आधी रात को लॉग फाइल को जनरेट करने के लिए।

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

# Define the file appender
log4j.appender.FILE=org.apache.log4j.DailyRollingFileAppender

# Set the name of the file
log4j.appender.FILE.File=${log}/log.out

# Set the immediate flush to true (default)
log4j.appender.FILE.ImmediateFlush=true

# Set the threshold to debug mode
log4j.appender.FILE.Threshold=debug

# Set the append to false, should not overwrite
log4j.appender.FILE.Append=true

# Set the DatePattern
log4j.appender.FILE.DatePattern='.' yyyy-MM-dd-a

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

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

आप उपरोक्त विन्यास के साथ log4j - नमूना कार्यक्रम का प्रयास कर सकते हैं ।

Log4j एपीआई org.apache.log4j.jdbc.JDBCAppender ऑब्जेक्ट प्रदान करता है , जो लॉगिंग जानकारी को एक निर्दिष्ट डेटाबेस में डाल सकता है।

JDBCAppender कॉन्फ़िगरेशन

संपत्ति विवरण
बफर आकार बफर आकार सेट करता है। डिफ़ॉल्ट आकार 1 है।
चालक ड्राइवर वर्ग को निर्दिष्ट स्ट्रिंग पर सेट करता है। यदि कोई ड्राइवर वर्ग निर्दिष्ट नहीं किया गया है, तो यह sun.jdbc.odbc.JdbcOdbcDriver पर डिफॉल्ट करता है।
ख़ाका उपयोग किए जाने वाले लेआउट को सेट करता है। डिफ़ॉल्ट लेआउट org.apache.log4j.PatternLayout है।
कुंजिका डेटाबेस पासवर्ड सेट करता है।
एसक्यूएल SQL कथन निर्दिष्ट करता है कि हर बार लॉगिंग ईवेंट होने पर निष्पादित किया जाता है। यह INSERT, UPDATE, या DELETE हो सकता है।
यूआरएल JDBC URL सेट करता है।
उपयोगकर्ता डेटाबेस उपयोगकर्ता नाम सेट करता है।

लॉग टेबल कॉन्फ़िगरेशन

इससे पहले कि आप JDBC आधारित लॉगिंग का उपयोग करना शुरू करें, आपको सभी लॉग जानकारी को बनाए रखने के लिए एक तालिका बनानी चाहिए। लॉग तालिका बनाने के लिए SQL कथन निम्नलिखित है:

CREATE TABLE LOGS
   (USER_ID VARCHAR(20) NOT NULL,
    DATED   DATE NOT NULL,
    LOGGER  VARCHAR(50) NOT NULL,
    LEVEL   VARCHAR(10) NOT NULL,
    MESSAGE VARCHAR(1000) NOT NULL
   );

नमूना विन्यास फाइल

JDBCAppender के लिए एक नमूना कॉन्फ़िगरेशन फ़ाइल log4j.properties निम्नलिखित है जिसका उपयोग लॉग्स तालिका में संदेशों को लॉग करने के लिए किया जाएगा।

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

# Define the DB appender
log4j.appender.DB=org.apache.log4j.jdbc.JDBCAppender

# Set JDBC URL
log4j.appender.DB.URL=jdbc:mysql://localhost/DBNAME

# Set Database Driver
log4j.appender.DB.driver=com.mysql.jdbc.Driver

# Set database user name and password
log4j.appender.DB.user=user_name
log4j.appender.DB.password=password

# Set the SQL statement to be executed.
log4j.appender.DB.sql=INSERT INTO LOGS VALUES('%x','%d','%C','%p','%m')

# Define the layout for file appender
log4j.appender.DB.layout=org.apache.log4j.PatternLayout

MySQL डेटाबेस के लिए, आपको वास्तविक DBNAME, उपयोगकर्ता आईडी और पासवर्ड का उपयोग करना होगा, जहाँ आपने LOGS तालिका बनाई है। SQL कथन तालिका नाम LOGS और तालिका में दर्ज किए जाने वाले मानों के साथ एक INSERT विवरण निष्पादित करने के लिए है।

JDBCAppender को स्पष्ट रूप से परिभाषित करने के लिए एक लेआउट की आवश्यकता नहीं है। इसके बजाय, इसमें दिया गया SQL कथन एक PatternLayout का उपयोग करता है।

यदि आप XML लॉग फ़ाइल को उपरोक्त log4j.properties फ़ाइल के बराबर चाहते हैं , तो यहाँ सामग्री है:

<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE log4j:configuration SYSTEM "log4j.dtd">
<log4j:configuration>

<appender name="DB" class="org.apache.log4j.jdbc.JDBCAppender">
   <param name="url" value="jdbc:mysql://localhost/DBNAME"/>
   <param name="driver" value="com.mysql.jdbc.Driver"/>
   <param name="user" value="user_id"/>
   <param name="password" value="password"/>
   <param name="sql" value="INSERT INTO LOGS VALUES('%x','%d','%C','%p','%m')"/>
   <layout class="org.apache.log4j.PatternLayout">
   </layout>
</appender>

<logger name="log4j.rootLogger" additivity="false">
   <level value="DEBUG"/>
   <appender-ref ref="DB"/>
</logger>

</log4j:configuration>

नमूना कार्यक्रम

निम्नलिखित जावा वर्ग एक बहुत ही सरल उदाहरण है जो जावा अनुप्रयोगों के लिए लॉग 4 जे लॉगिंग लाइब्रेरी का उपयोग करता है।

import org.apache.log4j.Logger;
import java.sql.*;
import java.io.*;
import java.util.*;

public class log4jExample{
   /* Get actual class name to be printed on */
   static Logger log = Logger.getLogger(log4jExample.class.getName());
   
   public static void main(String[] args)throws IOException,SQLException{
      log.debug("Debug");
      log.info("Info");
   }
}

संकलन और निष्पादन

उपर्युक्त कार्यक्रम को संकलित करने और चलाने के लिए यहां चरण दिए गए हैं। सुनिश्चित करें कि आपने सेट किया हैPATH तथा CLASSPATH संकलन और निष्पादन के लिए आगे बढ़ने से पहले उचित रूप से।

सभी पुस्तकालयों में उपलब्ध होना चाहिए CLASSPATHऔर आपकी log4j.properties फ़ाइल पथ में उपलब्ध होनी चाहिए। दिए गए चरणों का पालन करें:

  • जैसा कि ऊपर दिखाया गया है log4j.properties बनाएँ।
  • जैसा कि ऊपर दिखाया गया है log4jExample.java बनाएं और इसे संकलित करें।
  • प्रोग्राम को चलाने के लिए log4jExample बाइनरी निष्पादित करें।

अब DBNAME डेटाबेस के अंदर अपनी LOGS तालिका की जाँच करें और आपको निम्नलिखित प्रविष्टियाँ मिलेंगी:

mysql >  select * from LOGS;
+---------+------------+--------------+-------+---------+
| USER_ID | DATED      | LOGGER       | LEVEL | MESSAGE |
+---------+------------+--------------+-------+---------+
|         | 2010-05-13 | log4jExample | DEBUG | Debug   |
|         | 2010-05-13 | log4jExample | INFO  | Info    |
+---------+------------+--------------+-------+---------+
2 rows in set (0.00 sec)

Note:यहाँ x का उपयोग नीड डायग्नोस्टिक कॉन्सेप्ट (NDC) को उस थ्रेड से जुड़े आउटपुट से किया जाता है जो लॉगिंग ईवेंट उत्पन्न करता है। हम NDC का उपयोग कई क्लाइंट्स को संभालने वाले सर्वर-साइड घटकों में ग्राहकों को अलग करने के लिए करते हैं। इस पर अधिक जानकारी के लिए Log4J मैनुअल की जाँच करें।