로그 찍는 거 별로 안좋아하는데 로그를 찍어보니까 더 좋은 것 같아요 ^^
게다가 log4j라는 매우 우수한 로그찍는 프로그램이 있습니다.
sysout에서 벗어나봅시다-_-; 습관적으로 sysout을-_-(System.out.println()......-_-)

우선 이클립스에서 프로젝트를 하나 만들어봅시다.
log4j를 받아봅시다.
http://logging.apache.org/log4j/1.2/download.html
1.2버전입니다. 받아서 log4j-1.2.15.jar파일을 라이브러리에 추가합시다.

log4j설정파일을 만들어봅시다.
최상위 폴더에다가 log4j.properties파일을 만듭시다.
[code]
# Log4j Setting file
log4j.rootLogger=INFO, console

# Daily file log
log4j.appender.logfile=org.apache.log4j.DailyRollingFileAppender
log4j.appender.logfile.File=D:/mudchobo/Log/glv.log
log4j.appender.logfile.DatePattern='.'yyyy-MM-dd
log4j.appender.logfile.layout=org.apache.log4j.PatternLayout
log4j.appender.logfile.layout.ConversionPattern=[%d{HH:mm:ss}][%-5p](%F:%L) - %m%n

# Console log
log4j.appender.console=org.apache.log4j.ConsoleAppender
log4j.appender.console.layout=org.apache.log4j.PatternLayout
log4j.appender.console.layout.ConversionPattern=%-5p %l - %m%n

# log level and appender
log4j.logger.com.mudchobo=DEBUG, console
log4j.logger.com.mudchobo.Test=INFO, logfile
[/code]
대략 내용을 살펴보면 log4j.rootLogger는 최상위 로거입니다.
모든 INFO레벨이상의 로그는 다 console로 찍겠다는 겁니다.
(레벨에는 DEBUG, INFO, WARN, ERROR, FATAL 순인데, 예를 들어 INFO레벨로 지정해두면 logger.debug로 찍는 로그는 나타나지 않습니다. INFO레벨 이상것만 나타납니다.)

console은 아래 #Console log쪽에 보시면
log4j.appender.console <- 요 이름입니다.
요 console은 자세히보면 ConsoleAppender라는 클래스입니다. 이건 말그대로 콘솔에 로그를 찍어준다는 겁니다. layout에는 PatternLayout을 지정할 수 있는데 저 패턴은 뭐 레벨이 뭐고, 클래스가 뭐고, 메시지찍고 뭐 그런 내용입니다. 검색 고고싱-_-;

그리고, 파일에다가 출력 할 수 있는데, DailyRollingFileAppender클래스를 이용합니다. 이눔은 말그대로 매일매일 다른로그를 사용하게 만듭니다. 로그이름이 위와 같이 glv.log라면, 해당로그가 어제날짜인데 로그를 찍으려고 하면 기존에 있던 파일은 glv.log.2008-04-17 이렇게 바꿔줍니다.

아래부분에 보면 log4j.logger. 다음에 패키지명이나 클래스명을 지정해놓고, 로그레벨과 출력할 로그를 지정할 수 있는데요. 해당 클래스나 패키지의 로그는 저걸로 찍겠다는 겁니다. Test클래스는 logfile로 찍힌다는 겁니다.
그리고, rootLogger가 colsole로 지정되어 있기 때문에 console에도 찍히겠죠? ^^

로그를 찍어봅시다.
TestLogging이라는 프로젝트 이름으로 만듭시다.

Test클래스를 만들어봅시다.
Test.java
[code]
package com.mudchobo;

import org.apache.log4j.Logger;

public class Test {

 private Logger logger = Logger.getLogger(getClass());
 
 public void println() {
  logger.info("안녕하세요! Test입니다");
 }
}
[/code]
Test2클래스를 만들어봅시다.
Test2.java
[code]
package com.mudchobo;

import org.apache.log4j.Logger;

public class Test2 {

private Logger logger = Logger.getLogger(getClass());
 
 public void println() {
  logger.info("안녕하세요! Test2입니다.");
 }
}
[/code]
TestLogging클래스를 만들어봅시다. 메인을 만들어야합니다.
[code]
package com.mudchobo;

public class TestLogging {

 public static void main(String[] args) {
  Test test = new Test();
  Test2 test2 = new Test2();
 
  test.println();
  test2.println();
 }
}
[/code]
자 그럼 콘솔에는
INFO  com.mudchobo.Test.println(Test.java:10) - 안녕하세요! Test입니다.
INFO  com.mudchobo.Test.println(Test.java:10) - 안녕하세요! Test입니다.
INFO  com.mudchobo.Test2.println(Test2.java:10) - 안녕하세요! Test2입니다.
INFO  com.mudchobo.Test2.println(Test2.java:10) - 안녕하세요! Test2입니다.
이렇게 출력이 될 것이고 로그파일에는
[19:56:35][INFO ](Test.java:10) - 안녕하세요! Test입니다.
이것만 출력될 것입니다.
위에 콘솔에 두번 찍힌 이유는 Rootlogger도 찍고, 아래 패키지를 지정한 로그도 찍었기 때문이죠.
그리고, 파일에는 한번만 쓰여진 이유는 파일에 쓰는건
log4j.logger.com.mudchobo.Test=INFO, logfile 여기 이 Test클래스 하나죠-_-;
이상입니다-_-;


 
Posted by 머드초보

댓글을 달아 주세요

  1. BlogIcon 아이 2008.04.18 14:51  댓글주소  수정/삭제  댓글쓰기

    오오오~~멋진데~
    똑같은거 두번씩 찍히는건 log4j.additivity 옵션 한번 찾아보삼~

    • 머드초보 2008.04.18 19:23  댓글주소  수정/삭제

      두번찍는거 막는 옵션도 있는건가보군!
      방문해줘서 고맙네그려 ^^
      여긴 자네 서버인데-_-;

  2. 2008.05.14 13:55  댓글주소  수정/삭제  댓글쓰기

    log4j 의 막강한 기능은 로그 db 저장 및 원격 포트로 데이터를 쏘는 기능 까지 ..
    한번 테스트 겸 해보면 재미 있더라구.
    로칼의 알 ftp 에 보기 창에 로그가 찍히는데 재미 있던데 ㅋㅋ

    • 머드초보 2008.05.16 08:26  댓글주소  수정/삭제

      아 그렇군요 ^^
      log4j를 그냥 로그찍는 용도 밖에 안써봐서 ^^
      데이터를 원격으로 전송도 되는건가요?
      오...멋지네!

  3. BlogIcon 검쉰 2008.05.26 22:56  댓글주소  수정/삭제  댓글쓰기

    이번에 진행하는 프로젝트에 log4j 꼭 써야겠어요 ㅎㅎ
    좋은 글 감사합니다 ;)

  4. 솜소미 2012.08.10 11:27  댓글주소  수정/삭제  댓글쓰기

    오오 자세하고 쉬운 설명 감사드립니다~
    많은 도움 받고 갑니다. ^^

  5. MookMook 2014.07.11 10:32  댓글주소  수정/삭제  댓글쓰기

    감사합니다~ spring 말고 그냥 jsp/java 상에 넣을려고 많이 찾아다녔는데 여기서 답을 얻네요

  6. 으라챠챠 2015.06.17 16:46  댓글주소  수정/삭제  댓글쓰기

    좋은글이네요... 잘 읽고 갑니다... 수고하세요...