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

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

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

# 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 मैनुअल की जाँच करें।