log4j-데이터베이스에 로그인

log4j API는 org.apache.log4j.jdbc.JDBCAppender 지정된 데이터베이스에 로깅 정보를 넣을 수있는 개체입니다.

JDBCAppender 구성

특성 기술
버퍼 크기 버퍼 크기를 설정합니다. 기본 크기는 1입니다.
운전사 드라이버 클래스를 지정된 문자열로 설정합니다. 드라이버 클래스가 지정되지 않은 경우 기본값은sun.jdbc.odbc.JdbcOdbcDriver.
형세 사용할 레이아웃을 설정합니다. 기본 레이아웃은org.apache.log4j.PatternLayout.
암호 데이터베이스 암호를 설정합니다.
SQL 로깅 이벤트가 발생할 때마다 실행할 SQL 문을 지정합니다. INSERT, UPDATE 또는 DELETE 일 수 있습니다.
URL JDBC URL을 설정합니다.
사용자 데이터베이스 사용자 이름을 설정합니다.

로그 테이블 구성

JDBC 기반 로깅 사용을 시작하기 전에 모든 로그 정보를 유지하기위한 테이블을 만들어야합니다. 다음은 LOGS 테이블을 생성하는 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 LOGS 테이블에 메시지를 기록하는 데 사용되는 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 데이터베이스의 경우 LOGS 테이블을 생성 한 실제 DBNAME, 사용자 ID 및 비밀번호를 사용해야합니다. 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>

샘플 프로그램

다음 Java 클래스는 초기화 한 다음 Java 응용 프로그램 용 Log4J 로깅 라이브러리를 사용하는 매우 간단한 예제입니다.

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

컴파일 및 실행

위에서 언급 한 프로그램을 컴파일하고 실행하는 단계는 다음과 같습니다. 설정했는지 확인하십시오PATHCLASSPATH 컴파일 및 실행을 진행하기 전에 적절하게.

모든 라이브러리는 CLASSPATH하고 있는 log4j.properties 파일을 PATH에서 사용할 수 있습니다. 주어진 단계를 따르십시오-

  • 위에 표시된대로 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 (Nested diagnostic Context)를 출력하는 데 사용됩니다. NDC를 사용하여 여러 클라이언트를 처리하는 서버 측 구성 요소에서 클라이언트를 구분합니다. 이에 대한 자세한 내용은 Log4J 매뉴얼을 확인하십시오.