# Back-End/Spring

Logback과 slf4j 간단한 예제

왕꿀꿀 2022. 9. 2. 09:27

 

 

 

로그 레벨

  • TRACE : 추적 레벨은 DEBUG보다 좀 더 상세한 정보를 표시
  • DEBUG : 프로그램을 디버깅하기 위한 정보를 표시 (운영 서버에서는 표시하지 않도록 설정)
  • INFO : 상태 변경과 같은 정보성 로그를 표시
  • WARN : 처리 가능한 문제, 시스템 에러의 원인이 될 수 있는 경고성 메시지를 표시
  • ERROR : 요청을 처리하는 중 오류가 발생한 경우 표시

※ 로그 레벨로 설정한 값 이상의 로그가 출력됨 (EX: 로그 레벨 INFO : INFO, WARN, ERROR가 출력됨)

 

 

Yaml 단순 설정

# log
logging:
  level:
    root: INFO
    org:
      hibernate:
        SQL: OFF
        type:
          descriptor:
            sql:
              BasicBinder: OFF
  file:
    name: ${user.dir}/log/application.log  # 로그 파일 위치. 프로젝트 최상위 경로에 log 폴더가 생성됨
  logback:
    rolling-policy:
      max-history: 7 # 로그 파일 삭제 주기
      max-file-size: 10MB # 로그 파일 하나당 최대 파일 사이즈

더 복잡한 설정을 사용하려면 resource 폴더에 logback-spring.xml 파일을 생성하여 설정

  • 대소문자 구별 X
  • 크게 appender와 logger를 사용하여 설정
  • appender - 로그의 출력 형태(콘솔, 파일) 설정
  • logger - 로거마다 이름을 부여하여 사용, 패키지별 원하는 출력 레벨값 설정 (전역 설정 최상위 로거 = root)

 

테스트

로깅

log.trace("가장 디테일한 로그");
log.debug("디버깅용 로그");
log.info("정보성 로그");
log.warn("경고");

try{
    throw new Exception("Test Exception");
} catch (Exception e) {
    log.error("에러",e);
}

 

결과

2022-08-23 10:22:39.085  INFO 6783 --- [nio-8080-exec-2] c.d.study.web.controller.TestController  : 정보성 로그
2022-08-23 10:22:39.085  WARN 6783 --- [nio-8080-exec-2] c.d.study.web.controller.TestController  : 경고
2022-08-23 10:22:39.089 ERROR 6783 --- [nio-8080-exec-2] c.d.study.web.controller.TestController  : 에러

java.lang.Exception: Test Exception
	...

 

현재 INFO 레벨까지만 출력되도록 설정하여 trace, debug는 출력되지 않음

728x90