728x90

기본 Log 설정 및 Logback 설정

Spring Boot 는 내부로그는 Commons Logging 사용한다. Java Util Logging 、Log4J2 과 Logback 등 library 들을 자동옵션으로 두었다. 3가지 로그는 모두 IDE 툴 터미널에서 로그를 구체적으로 찍일수 있다. 오늘은 Logback 관련해서 알아보자

  1. 시간일자:ms 단위
  1. 로그레벨:ERROR, WARN, INFO, DEBUG or TRACE
  1. 프로세스 ID
  1. 구분자 :--- 로그시작점
  1. thread id:
  1. Logger名:클래스 명으로 대체
  1. 로그내용.
  • 로그실제 찍히는 것
2021-12-28 17:37:25.578  INFO 65136 --- [           main] com.didispace.chapter81.Application      : Started Application in 2.695 seconds (JVM running for 3.957)2021-12-28 17:37:25.579 ERROR 65136 --- [           main] com.didispace.chapter81.Application      : Hello World
2021-12-28 17:37:25.579 ERROR 65136 --- [           main] com.didispace.chapter81.Application      : Hello World
2021-12-28 17:37:25.579  WARN 65136 --- [           main] com.didispace.chapter81.Application      : Hello World
2021-12-28 17:37:25.579  INFO 65136 --- [           main] com.didispace.chapter81.Application      : Hello World

  • 로그모드 변경 방법 2가지
$ java -jar myapp.jar --debug

application.properties 에서 debug=true 속성 추가

debug=true 

로그설정

  • 컬러 설정

application.properties 에 spring.output.ansi.enabled 속성 추가

NEVER : ANSI-colored 사용안함.

DETECT : ANSI 여부를 판단하고 맞으면 color 로 로그출력

ALWAYS : 항상 ANSI-colored 모드로 출력 ,ANSI 지원하지 않을시 여러가지 "잡"정보가 나오므로 추천하지 않음.

Spring Boot 1.x 기본 NEVER 이지만 2.x 버전 이후 DETECT 로 변경 됨. 때문에 위 로그 이미지는 기본으로 컬러가 출력 되었다. 요즘 다들 Spring Boot 2.x 를 사용하기때문에 별도로 컬러 설절은 하지 않아도 된다.
  • 로그파일 만들기

application.properties 에

logging.file.name=run.log #파일명

logging.file.path=./ #파일경로

  • 로그파일 롤링
**logging.logback.rollingpolicy.file-name-pattern: "/logs/abc.%d{yyyy-MM-dd}.%i" #파일 생성 규칙 패턴**
**logging.logback.rollingpolicy.clean-history-on-start: # 구동시 기존 로그 지우는가 ,기본 false 임.**
**logging.logback.rollingpolicy.max-history: 30 # 로그파일 유지 개수**
**logging.logback.rollingpolicy.max-file-size: # 파일별 사이즈 제한**
**logging.logback.rollingpolicy.total-size-cap: #**

Log Level 컨틀롤

  • 설정 포맷
💡
logging.level.*=LEVEL
💡
logging.level : * 은 패키지 명 혹은 Logger 명
💡
LEVEL : TRACE, DEBUG, INFO, WARN, ERROR, FATAL, OFF
  • 예시
**logging.level.com.didispace=DEBUG # com.blake 패키지하위 모든 class는 DEBUG 레벨사용**
**logging.level.root=WARN #root 관련은 로그는 WARN level 사용**
  • 커스텀 설정

일반적으로 ApplicationContext 생성서 Log 모듈이 초기화 된다. Spring 설정파일의 영향을 받지 않는다. 때문에 Springboot 외부에서 Log관련 설정을 자유롭게 할수 있다.

아래와 같은 이름을 springboot에서 사용하는데

💡
Logback:logback-spring.xml, logback-spring.groovy, logback.xml, logback.groovy
💡
Log4j2:log4j2-spring.xml, log4j2.xml
💡
JDK (Java Util Logging):logging.properties

SpringBoot 공식사이트에서 -spring 를 붙여서 사용하라고 권장한다.

logback.xml 아닌 logback-spring.xml 을 사용해야 된다.

추가로 application.properties 에 아래와 같은 속성 값도 설정가능하다.

logging.pattern.console:터미널에 찍힐 로그 양식 (JDK Logger 안됨.)

logging.pattern.file:파일에 쓰기위한 로그 양식(JDK Logger 안됨.)

끝!


내저장소 바로가기 luxury515

'Springboot2.x 강좌 > 로그의 기본설정' 카테고리의 다른 글

Springboot 2.6.x 설정 및 사용  (0) 2023.04.11
TinyLog 사용하기  (0) 2023.04.11

+ Recent posts