일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
1 | 2 | 3 | 4 | |||
5 | 6 | 7 | 8 | 9 | 10 | 11 |
12 | 13 | 14 | 15 | 16 | 17 | 18 |
19 | 20 | 21 | 22 | 23 | 24 | 25 |
26 | 27 | 28 | 29 | 30 | 31 |
- oracle
- python
- write by chatGPT
- 리눅스
- 자바암호
- flet
- 웹 크롤링
- Java
- 자바
- spring data jpa
- chatGPT's answer
- JVM
- 데이터베이스
- GPT-4's answer
- 시스템
- 코틀린
- write by GPT-4
- android
- NIO
- Database
- kotlin
- jpa
- 유닉스
- 고전역학
- 자바네트워크
- 역학
- 인프라
- 소프트웨어공학
- 파이썬
- spring integration
- Today
- Total
기억을 지배하는 기록
Jakarta Commons Logging 본문
소개
Jakarta Commons Logging(JCL)은 많은 로깅 툴킷에 독립적인 경량의 로그 인터페이스이다. JCL은 미들웨어 및 툴 개발자에게 단순한 로깅 추상화 계층을 제공하기 때문에 사용자(애플리케이션 개발자)는 특정 로깅 구현체를 플러그인하여 사용할 수 있게 된다. JCL은 Log4j, Avalon LogKit, JDK1.4를 포함한 다른 로깅 툴에 대한 경량의 래퍼(wrapper) 구현체에 대한 로그 인터페이스를 제공한다.
설정
JCL에는 다음과 같은 기본이 되는 두 가지 추상 클래스가 있다.
Log: 기본 Logger 인터페이스
LogFactory: Log 객체를 생성하는 방법을 알고 있는 추상 클래스
더 자세히 살펴본다면, JCL은 아래와 같이 구성되어 있다.
org.apache.commons.logging
Log: 다양한 로깅 API를 추상화시키는 단순한 로깅 인터페이스
LogFactory: Java API 중에서 JAXP와 유사하게 configuration과 관련 클래스를 찾는 과정을 거쳐서 Log의 인스턴스를 생성하는 추상 클래스
LogSource: Log 인스턴스를 생성하는 팩토리 객체
LogConfigurationException
org.apache.commons.logging.impl
Jdk14Logger: org.apache.commons.logging.Log 인터페이스의 구현체. JDK1.4에 소개된 표준 JDK 로깅 매커니즘을 래핑했다
Log4JCategoryLog
Log4jFactory
Log4JLogger: Log4J에 직접 매핑(mapping)된 Log 인터페이스의 구현체
LogFactoryImpl
LogKitLogger: avalon-logkit를 랩핑한 Log 인터페이스의 구현체
NoOpLog
SimpleLog
LogFactory는 아래와 같은 절차에 따라서 Log 구현체를 찾는다. 아래 과정은 순서대로 진행되고, 제일 처음 성공한 단계 이후의 과정은 진행시키지 않는다.
LogFactory에 대한 configuration 속성 중에서 org.apache.commons.logging.Log라는 속성을 찾는다
시스템 프로퍼티에서 이 속성을 찾는다
애플리케이션 클래스 패스안에 Log4j 로깅 시스템를 찾는다. 만약 애플리케이션의 클래스 패스에 Log4j 로깅 시스템에 대해서 찾았다면, Log4j에 관련된 래핑 클래스인 Log4JLogger를 이용한다
애플리케이션이 만약 JDK1.4 시스템에서 구동 중이라면, JDK 1.4과 관련된 래핑 클래스인 Jdk14Logger를 이용한다
위 과정 모두 실패했다면, SimpleLog라는 디폴트로 제공되는 로깅 래핑 클래스를 사용한다
사용
JCL를 사용하는 과정은 아래와 같다.
LogFactory.getFactory()를 호출하여 LogFactory 객체를 얻는다
위 과정에서 얻어진 LogFactory 객체의 getInstance(String name)라는 메소드를 호출하여 org.apache.commons.logging.Log 형의 인스턴스를 얻어낸다
이렇게 얻어낸 Log형의 인스턴스의 debug(), info(), warn(), error(), fatal() 함수를 호출하여 로그 기능을 이용한다
예제
import org.apache.commons.logging.Log;
import org.apache.commons.logging.LogFactory;
public class MyComponent {
protected static Log log = LogFactory.getLog("my.component");
//보통 my.component에는 패키지명을 적습니다.
// Called once at startup time
public void start() {
...
log.info("MyComponent started");
...
}
// Called once at shutdown time
public void stop() {
...
log.info("MyComponent stopped");
...
}
// Called repeatedly to process a particular argument value
// which you want logged if debugging is enabled
public void process(String value) {
...
// Do the string concatenation only if logging is enabled
if (log.isDebugEnabled())
log.debug("MyComponent processing " + value);
...
}
}
왜 JCL을 사용해야 하는가?
XML 관련 프로그래밍을 해봤다면 JAXP를 사용해봤을 것이다. 디렉토리 서비스 관련 프로그래밍을 해봤다면 JNDI를 사용해봤을 것이다. 또한, RDBMS 관련 프로그래밍을 해봤다면 JDBC를 사용해봤을 것이다. 이 모두가 특정 구현체에 종속되지 않는 애플리케이션 작성을 위한 공통 인터페이스를 제공한다. JCL도 마찬가지라고 생각하면 된다. 많은 로깅 관련 구현체가 있는데, 특정 로깅 관련 구현체에 종속되지 않는 애플리케이션 구현을 위해서는 JCL을 사용하는 것이 좋을 것이다.
'오래된글 > Java' 카테고리의 다른 글
Java 네트워크 - 2 (0) | 2018.04.09 |
---|---|
Java 네트워크 - 1 (0) | 2018.04.09 |
Jakarta Common Configuration (0) | 2018.04.07 |
Introduce Junit4.0 (0) | 2018.04.07 |
HybridJava(HJ) - Beyond the Java Server Pages (0) | 2018.04.07 |