log4j-퀵 가이드
log4j는 Java로 작성된 안정적이고 빠르며 유연한 로깅 프레임 워크 (API)로 Apache Software License에 따라 배포됩니다.
log4j는 C, C ++, C #, Perl, Python, Ruby 및 Eiffel 언어로 포팅되었습니다.
log4j는 런타임에 외부 구성 파일을 통해 고도로 구성 할 수 있습니다. 우선 순위 수준에서 로깅 프로세스를보고 로깅 정보를 데이터베이스, 파일, 콘솔, UNIX Syslog 등과 같은 매우 다양한 대상으로 보내는 메커니즘을 제공합니다.
log4j에는 세 가지 주요 구성 요소가 있습니다.
loggers: 로깅 정보 캡처를 담당합니다.
appenders: 다양한 선호 대상에 로깅 정보 게시를 담당합니다.
layouts: 다양한 스타일의 로깅 정보 형식화를 담당합니다.
log4j의 역사
1996 년 초 EU SEMPER (Secure Electronic Marketplace for Europe) 프로젝트를위한 추적 API로 시작되었습니다.
수많은 개선과 몇 가지 구현 이후, 초기 API는 Java 용으로 널리 사용되는 로깅 패키지 인 log4j로 발전했습니다.
이 패키지는 오픈 소스 이니셔티브에서 인증 한 본격적인 오픈 소스 라이선스 인 Apache Software License에 따라 배포됩니다.
전체 소스 코드, 클래스 파일 및 문서를 포함한 최신 log4j 버전은 다음에서 찾을 수 있습니다. http://logging.apache.org/log4j/.
log4j 기능
스레드로부터 안전합니다.
속도에 최적화되어 있습니다.
명명 된 로거 계층 구조를 기반으로합니다.
로거 당 여러 출력 어 펜더를 지원합니다.
국제화를 지원합니다.
미리 정의 된 기능 세트로 제한되지 않습니다.
로깅 동작은 구성 파일을 사용하여 런타임에 설정할 수 있습니다.
처음부터 Java 예외를 처리하도록 설계되었습니다.
ALL, TRACE, DEBUG, INFO, WARN, ERROR 및 FATAL과 같은 여러 수준을 사용합니다.
로그 출력의 형식은 Layout 클래스 를 확장하여 쉽게 변경할 수 있습니다 .
로그 출력의 대상과 쓰기 전략은 Appender 인터페이스의 구현에 의해 변경 될 수 있습니다.
페일 스톱입니다. 그러나 확실히 전달을 보장하기 위해 노력하고 있지만 log4j는 각 로그 문이 대상으로 전달된다는 것을 보장하지 않습니다.
로깅의 장단점
로깅은 소프트웨어 개발의 중요한 구성 요소입니다. 잘 작성된 로깅 코드는 응용 프로그램의 런타임 정보에 대한 빠른 디버깅, 쉬운 유지 관리 및 구조화 된 저장소를 제공합니다.
로깅에는 단점도 있습니다. 응용 프로그램 속도가 느려질 수 있습니다. 너무 장황하면 스크롤링 실명을 유발할 수 있습니다. 이러한 문제를 완화하기 위해 log4j는 안정적이고 빠르며 확장 가능하도록 설계되었습니다.
로깅이 애플리케이션의 주요 초점이되는 경우는 드물기 때문에 log4j API는 이해하고 사용하기 간편하도록 노력합니다.
log4j API 패키지는 오픈 소스 이니셔티브에서 인증 한 본격적인 오픈 소스 라이선스 인 Apache Software License에 따라 배포됩니다.
전체 소스 코드, 클래스 파일 및 문서를 포함한 최신 log4j 버전은 http://logging.apache.org/log4j/.
시스템에 log4j를 설치하려면 지정된 URL에서 apache-log4j-xxxtar.gz를 다운로드하고 아래 단계를 따르십시오.
1 단계
다음과 같이 / usr / local / 디렉토리에 다운로드 한 파일의 압축을 풀고 압축을 풉니 다.
$ 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/
.......................................
압축을 푸는 동안 다음과 같이 이름이 apache-log4j-xxx 인 디렉토리 계층을 생성합니다.
-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 프레임 워크에서 사용할 기능에 따라 다릅니다. 컴퓨터에 다음 패키지가 이미 설치되어 있으면 괜찮습니다. 그렇지 않으면 log4j가 작동하도록 패키지를 설치해야합니다.
JavaMail API:log4j의 이메일 기반 로깅 기능을 사용하려면 glassfish.dev 에서 시스템에 Java Mail API (mail.jar)를 설치해야합니다 .
JavaBeans Activation Framework: Java Mail API를 사용하려면 JavaBeans Activation Framework (activation.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 API는 각 계층이 서로 다른 작업을 수행하기 위해 서로 다른 객체를 제공하는 계층화 된 아키텍처를 따릅니다. 이 계층화 된 아키텍처는 설계를 유연하고 향후 확장하기 쉽게 만듭니다.
log4j 프레임 워크에서 사용할 수있는 두 가지 유형의 객체가 있습니다.
Core Objects:이들은 프레임 워크의 필수 개체입니다. 프레임 워크를 사용하려면 필요합니다.
Support Objects:프레임 워크의 선택적 개체입니다. 추가하지만 중요한 작업을 수행하기 위해 핵심 개체를 지원합니다.
핵심 개체
핵심 개체에는 다음 유형의 개체가 포함됩니다.
로거 개체
최상위 계층은 Logger 개체를 제공하는 Logger입니다. Logger 개체는 로깅 정보를 캡처하는 역할을하며 네임 스페이스 계층 구조에 저장됩니다.
레이아웃 개체
레이아웃 레이어는 다양한 스타일로 로깅 정보의 형식을 지정하는 데 사용되는 개체를 제공합니다. 로깅 정보를 게시하기 전에 appender 개체를 지원합니다.
레이아웃 개체는 사람이 읽고 재사용 할 수있는 방식으로 로깅 정보를 게시하는 데 중요한 역할을합니다.
어 펜더 객체
Appender 개체를 제공하는 하위 수준의 레이어입니다. Appender 개체는 데이터베이스, 파일, 콘솔, UNIX Syslog 등과 같은 다양한 선호 대상에 로깅 정보를 게시하는 역할을합니다.
다음 가상 다이어그램은 log4J 프레임 워크의 구성 요소를 보여줍니다.
지원 개체
로깅 프레임 워크에서 중요한 역할을하는 log4j 프레임 워크에는 다른 중요한 개체가 있습니다.
레벨 개체
Level 개체는 로깅 정보의 세분성과 우선 순위를 정의합니다. API에는 OFF, DEBUG, INFO, ERROR, WARN, FATAL 및 ALL의 7 가지 수준의 로깅이 정의되어 있습니다.
필터 개체
Filter 개체는 로깅 정보를 분석하고 해당 정보의 로깅 여부에 대한 추가 결정을 내리는 데 사용됩니다.
Appender 개체에는 연결된 여러 필터 개체가있을 수 있습니다. 로깅 정보가 특정 Appender 개체에 전달되는 경우 해당 Appender와 연결된 모든 필터 개체는 로깅 정보를 승인해야 연결된 대상에 게시 할 수 있습니다.
ObjectRenderer
ObjectRenderer 개체는 로깅 프레임 워크에 전달 된 여러 개체의 문자열 표현을 제공하는 데 특화되어 있습니다. 이 개체는 레이아웃 개체에서 최종 로깅 정보를 준비하는 데 사용됩니다.
LogManager
LogManager 개체는 로깅 프레임 워크를 관리합니다. 시스템 전체 구성 파일 또는 구성 클래스에서 초기 구성 매개 변수를 읽는 역할을합니다.
이전 장에서는 log4j의 핵심 구성 요소에 대해 설명했습니다. 이 장에서는 구성 파일을 사용하여 핵심 구성 요소를 구성하는 방법에 대해 설명합니다. log4j 구성에는 레벨 할당, Appender 정의 및 구성 파일에서 레이아웃 객체 지정이 포함됩니다.
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는 $ {variableName}과 같은 UNIX 스타일 변수 대체를 지원한다는 점에 유의해야합니다.
디버그 수준
우리는 두 어 펜더와 함께 DEBUG를 사용했습니다. 가능한 모든 옵션은 다음과 같습니다.
- TRACE
- DEBUG
- INFO
- WARN
- ERROR
- FATAL
- ALL
이러한 수준은 log4j 로깅 수준에 설명되어 있습니다 .
어 펜더
Apache log4j는 주로 콘솔, 파일, 소켓, NT 이벤트 로그 등과 같은 다른 대상에 로깅 메시지를 인쇄하는 Appender 개체를 제공합니다.
각 Appender 개체에는 연결된 다른 속성이 있으며 이러한 속성은 해당 개체의 동작을 나타냅니다.
특성 | 기술 |
---|---|
형세 | Appender는 레이아웃 개체 및 이와 관련된 변환 패턴을 사용하여 로깅 정보의 형식을 지정합니다. |
표적 | 대상은 어 펜더에 따라 콘솔, 파일 또는 다른 항목이 될 수 있습니다. |
수평 | 수준은 로그 메시지의 필터링을 제어하는 데 필요합니다. |
문지방 | Appender는 로거 수준과 관계없이 관련된 임계 값 수준을 가질 수 있습니다. Appender는 임계 값 수준보다 낮은 수준의 모든 로깅 메시지를 무시합니다. |
필터 | Filter 개체는 수준 일치를 넘어서 로깅 정보를 분석하고 로깅 요청을 특정 Appender가 처리해야하는지 아니면 무시해야하는지 여부를 결정할 수 있습니다. |
다음 방법을 사용하여 구성 파일에 다음 설정을 포함하여 Appender 개체를 Logger에 추가 할 수 있습니다.
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>
프로그램 내부에 Appender 객체를 추가하려면 다음 방법을 사용할 수 있습니다.
public void addAppender(Appender appender);
addAppender () 메서드는 Logger 객체에 Appender를 추가합니다. 예제 구성에서 알 수 있듯이 쉼표로 구분 된 목록의 로거에 여러 Appender 개체를 추가 할 수 있으며, 각각은 별도의 대상에 로깅 정보를 인쇄합니다.
위의 예제 에서는 하나의 어 펜더 FileAppender 만 사용했습니다 . 가능한 모든 어 펜더 옵션은 다음과 같습니다.
- AppenderSkeleton
- AsyncAppender
- ConsoleAppender
- DailyRollingFileAppender
- ExternallyRolledFileAppender
- FileAppender
- JDBCAppender
- JMSAppender
- LF5Appender
- NTEventLogAppender
- NullAppender
- RollingFileAppender
- SMTPAppender
- SocketAppender
- SocketHubAppender
- SyslogAppender
- TelnetAppender
- WriterAppender
파일 로깅에서 FileAppender를 다루고 데이터베이스 에서 로깅에서 JDBC Appender를 다룹니다 .
형세
어 펜더와 함께 PatternLayout을 사용했습니다. 가능한 모든 옵션은 다음과 같습니다.
- 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 사용
다음 Java 클래스는 Java 응용 프로그램 용 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 파일을 PATH에서 사용할 수 있습니다. 아래 단계를 따르십시오.
위에 표시된대로 log4j.properties를 생성합니다.
위와 같이 log4jExample.java를 생성하고 컴파일합니다.
log4jExample 바이너리를 실행하여 프로그램을 실행합니다.
/usr/home/log4j/log.out 파일에 다음 결과가 표시됩니다.
Hello this is a debug message
Hello this is an info message
Logger 클래스는 로깅 활동을 처리하는 다양한 방법을 제공합니다. Logger 클래스는 새 Logger 인스턴스를 인스턴스화하는 것을 허용하지 않지만 Logger 객체를 얻기위한 두 가지 정적 메서드를 제공합니다.
- public static Logger getRootLogger();
- public static Logger getLogger(String name);
두 메서드 중 첫 번째는 응용 프로그램 인스턴스의 루트 로거를 반환하며 이름이 없습니다.
다른 명명 된 Logger 개체 인스턴스는 로거의 이름을 전달하여 두 번째 메서드를 통해 가져옵니다. 로거의 이름은 전달할 수있는 모든 문자열이 될 수 있으며, 일반적으로 마지막 장에서 사용한 클래스 또는 패키지 이름이며 아래에 언급되어 있습니다.
static Logger log = Logger.getLogger(log4jExample.class.getName());
로깅 방법
명명 된 로거의 인스턴스를 얻으면 로거의 여러 방법을 사용하여 메시지를 기록 할 수 있습니다. Logger 클래스에는 로깅 정보를 인쇄하기위한 다음과 같은 메서드가 있습니다.
Sr. 아니요 | 방법 및 설명 |
---|---|
1 | public void debug(Object message)
Level.DEBUG 레벨로 메시지를 인쇄합니다. |
2 | public void error(Object message)
Level.ERROR 수준의 메시지를 인쇄합니다. |
삼 | public void fatal(Object message);
Level.FATAL 수준의 메시지를 인쇄합니다. |
4 | public void info(Object message);
Level.INFO 레벨로 메시지를 인쇄합니다. |
5 | public void warn(Object message);
Level.WARN 수준의 메시지를 인쇄합니다. |
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.Level 클래스는 다음 레벨을 제공합니다. Level 클래스를 하위 분류하여 사용자 지정 수준을 정의 할 수도 있습니다.
수평 | 기술 |
---|---|
모두 | 사용자 지정 수준을 포함한 모든 수준. |
디버그 | 애플리케이션을 디버그하는 데 가장 유용한 세분화 된 정보 이벤트를 지정합니다. |
정보 | 대략적인 수준에서 응용 프로그램의 진행 상황을 강조하는 정보 메시지를 지정합니다. |
경고 | 잠재적으로 유해한 상황을 지정합니다. |
오류 | 애플리케이션이 계속 실행되도록 허용 할 수있는 오류 이벤트를 지정합니다. |
치명적인 | 응용 프로그램을 중단 할 수있는 매우 심각한 오류 이벤트를 지정합니다. |
떨어져서 | 가능한 가장 높은 순위이며 로깅을 해제하기위한 것입니다. |
자취 | DEBUG보다 더 세분화 된 정보 이벤트를 지정합니다. |
레벨은 어떻게 작동합니까?
레벨의 로그 요청 p 레벨이있는 로거에서 qp> = q 인 경우 활성화됩니다. 이 규칙은 log4j의 핵심입니다. 레벨이 정렬되어 있다고 가정합니다. 표준 레벨의 경우 ALL <DEBUG <INFO <WARN <ERROR <FATAL <OFF가 있습니다.
다음 예제는 모든 DEBUG 및 INFO 메시지를 필터링하는 방법을 보여줍니다. 이 프로그램은 로거 메소드 setLevel (Level.X)을 사용하여 원하는 로깅 수준을 설정합니다.
이 예는 Debug 및 Info를 제외한 모든 메시지를 인쇄합니다.
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 객체를받습니다. 그런 다음 Layout 객체는 LoggingEvent에서 메시지 인수를 검색하고 적절한 ObjectRenderer를 적용하여 메시지의 문자열 표현을 얻습니다.
레이아웃 유형
계층 구조의 최상위 클래스는 추상 클래스 org.apache.log4j.Layout입니다. 이것은 log4j API의 다른 모든 레이아웃 클래스에 대한 기본 클래스입니다.
Layout 클래스는 애플리케이션 내에서 추상으로 정의되며이 클래스를 직접 사용하지 않습니다. 대신 다음과 같은 하위 클래스로 작업합니다.
DateLayout
HTMLLayout
PatternLayout.
SimpleLayout
XMLLayout
레이아웃 방법
이 클래스는 다른 모든 Layout 객체에 대한 모든 공통 작업의 골격 구현을 제공하고 두 개의 추상 메서드를 선언합니다.
Sr. 아니. | 방법 및 설명 |
---|---|
1 | public abstract boolean ignoresThrowable()
로깅 정보가 로깅 이벤트의 일부로 전달 된 java.lang.Throwable 객체를 처리하는지 여부를 나타냅니다. Layout 객체가 Throwable 객체를 처리하는 경우 Layout 객체는이를 무시하지 않고 false를 반환합니다. |
2 |
public abstract String format(LoggingEvent event)
개별 레이아웃 하위 클래스는 레이아웃 특정 형식을 위해이 메서드를 구현합니다. |
이러한 추상 메서드 외에도 Layout 클래스는 아래 나열된 메서드에 대한 구체적인 구현을 제공합니다.
Sr. 아니. | 방법 및 설명 |
---|---|
1 |
public String getContentType()
레이아웃 개체에서 사용하는 콘텐츠 유형을 반환합니다. 기본 클래스는 기본 콘텐츠 유형으로 text / plain을 반환합니다. |
2 |
public String getFooter()
로깅 메시지의 바닥 글 정보를 지정합니다. |
삼 |
public String getHeader()
로깅 메시지의 헤더 정보를 지정합니다. |
각 하위 클래스는 이러한 메서드의 구체적인 구현을 재정 의하여 클래스 별 정보를 반환 할 수 있습니다.
로깅 정보를 파일에 쓰려면 org.apache.log4j.FileAppender 를 사용해야 합니다.
FileAppender 구성
FileAppender에는 다음과 같은 구성 가능한 매개 변수가 있습니다.
특성 | 기술 |
---|---|
즉시 플러시 | 이 플래그는 기본적으로 true로 설정되며 이는 각 추가 작업으로 플러시되는 파일에 대한 출력 스트림을 의미합니다. |
부호화 | 모든 문자 인코딩을 사용할 수 있습니다. 기본적으로 플랫폼 별 인코딩 체계입니다. |
문지방 | 이 어 펜더의 임계 값 수준입니다. |
파일 이름 | 로그 파일의 이름입니다. |
fileAppend | 이는 기본적으로 true로 설정되며 이는 동일한 파일의 끝에 로깅 정보가 추가됨을 의미합니다. |
bufferedIO | 이 플래그는 버퍼링 된 쓰기를 활성화해야하는지 여부를 나타냅니다. 기본적으로 false로 설정됩니다. |
버퍼 크기 | 버퍼링 된 I / O가 활성화 된 경우 버퍼 크기를 나타냅니다. 기본적으로 8kb로 설정되어 있습니다. |
다음은 FileAppender에 대한 샘플 구성 파일 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
위의 log4j.properties 파일 과 동일한 XML 구성 파일을 원하면 다음 내용이 있습니다.
<?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-샘플 프로그램 을 사용해 볼 수 있습니다.
여러 파일에 로그인
특정 이유 (예 : 파일 크기가 특정 임계 값에 도달 한 경우)로 인해 로그 메시지를 여러 파일에 기록 할 수 있습니다.
로깅 정보를 여러 파일에 쓰려면 FileAppender 클래스 를 확장하고 모든 속성을 상속 하는 org.apache.log4j.RollingFileAppender 클래스 를 사용해야 합니다.
위에서 언급 한 FileAppender에 대해 다음과 같은 구성 가능한 매개 변수가 있습니다.
특성 | 기술 |
---|---|
maxFileSize | 파일이 롤링 될 파일의 임계 크기입니다. 기본값은 10MB입니다. |
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 구성 파일이 필요한 경우 초기 섹션에서 언급 한 것과 동일한 파일을 생성하고 RollingFileAppender 와 관련된 추가 매개 변수 만 추가 할 수 있습니다 .
이 예제 구성은 각 로그 파일의 최대 허용 크기가 5MB임을 보여줍니다. 최대 크기를 초과하면 새 로그 파일이 생성됩니다. 이후 maxBackupIndex가 2로 정의되는 제 2 로그 파일의 최대 사이즈에 도달하면, 제 로그 파일은 소거되며, 그 후, 모든 로그 정보는 제 로그 파일에 다시 압연한다.
위의 구성으로 log4j-샘플 프로그램 을 사용해 볼 수 있습니다.
일일 로그 파일 생성
로깅 정보의 깨끗한 기록을 유지하기 위해 매일 로그 파일을 생성해야 할 수 있습니다.
로깅 정보를 매일 파일에 쓰려면 FileAppender 클래스 를 확장하고 모든 속성을 상속 하는 org.apache.log4j.DailyRollingFileAppender 클래스 를 사용해야 합니다.
FileAppender에 대해 위에서 언급 한 매개 변수 외에 구성 가능한 중요한 매개 변수는 하나뿐입니다.
특성 | 기술 |
---|---|
DatePattern | 이는 파일을 롤오버 할시기와 따라야 할 명명 규칙을 나타냅니다. 기본적으로 롤오버는 매일 자정에 수행됩니다. |
DatePattern은 다음 패턴 중 하나를 사용하여 롤오버 일정을 제어합니다.
DatePattern | 기술 |
---|---|
'.' yyyy-MM | 매월 말과 다음 달 초에 이월합니다. |
'.' yyyy-MM-dd | 매일 자정에 롤오버합니다. 이것이 기본값입니다. |
'.' yyyy-MM-dd-a | 매일 정오와 자정에 롤오버합니다. |
'.' yyyy-MM-dd-HH | 매시간 맨 위에 롤오버하십시오. |
'.' yyyy-MM-dd-HH-mm | 1 분마다 롤오버합니다. |
'.' 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 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
);
샘플 구성 파일
다음은 LOGS 테이블에 메시지를 기록하는 데 사용되는 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 데이터베이스의 경우 LOGS 테이블을 생성 한 실제 DBNAME, 사용자 ID 및 비밀번호를 사용해야합니다. SQL 문은 테이블 이름 LOGS와 테이블에 입력 할 값으로 INSERT 문을 실행하는 것입니다.
JDBCAppender는 레이아웃을 명시 적으로 정의 할 필요가 없습니다. 대신 전달 된 SQL 문은 PatternLayout을 사용합니다.
위의 log4j.properties 파일 과 동일한 XML 구성 파일을 원하면 다음 내용이 있습니다.
<?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");
}
}
컴파일 및 실행
위에서 언급 한 프로그램을 컴파일하고 실행하는 단계는 다음과 같습니다. 설정했는지 확인하십시오PATH 과 CLASSPATH 컴파일 및 실행을 진행하기 전에 적절하게.
모든 라이브러리는 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 매뉴얼을 확인하십시오.