반응형
SMALL
sql 관련 로그들만 안보이도록 수정해야 해서
logback.xml 에
<?xml version="1.0" encoding="UTF-8"?>
<configuration debug="true">
<!-- Appenders -->
<appender name="console" class="ch.qos.logback.core.ConsoleAppender">
<encoder>
<Pattern>%d %5p [%c] %m%n</Pattern>
</encoder>
</appender>
<appender name="console-infolog" class="ch.qos.logback.core.ConsoleAppender">
<encoder>
<Pattern>%d %5p %m%n</Pattern>
</encoder>
</appender>
<!-- Logger -->
<logger name="com.board" level="DEBUG" appender-ref="console" />
<logger name="jdbc.sqlonly" level="INFO" appender-ref="console-infolog" />
<logger name="jdbc.resultsettable" level="INFO" appender-ref="console-infolog" />
<!-- Root Logger -->
<root level="off">
<appender-ref ref="console" />
</root>
</configuration>
<logger name="패키지명" appender-ref="출력위치" level="로그레벨"/>
이런 값들이 들어가니
name에 sql 돌리는 코드 있는 패키지 명을 입력하고
appender-ref 에는 consolelevel 에는 off
로 해주니 sql 관련 로그들이 콘솔에 안 찍히는 것을 확인할 수 있었습니다.
xml에 선언한 내용에 대해 간략히 알아보도록 하겠습니다.
태그 | 설명 |
appender | 전달받은 로그를 어디에 출력할지 결정합니다. (콘솔 출력, 파일 저장, 데이터베이스 저장 등) |
encoder | appender에 포함되어 출력할 로그의 형식을 지정합니다. |
logger | 로그를 출력하는 요소로, level 속성을 통해 출력할 로그의 레벨을 조절하여 appender에 전달합니다. 첫 번째 logger에서 com.board는 src/main/java 디렉터리 안의 자바 패키지 경로를 의미합니다. |
이번에는 로그의 레벨에 대해 알아보도록 하겠습니다.
레벨 | 설명 |
fatal | 아주 심각한 에러가 발생한 상태를 나타냅니다. |
error | 요청을 처리하던 중 문제가 발생한 상태를 나타냅니다. |
warn | 프로그램 실행에는 문제가 없지만, 나중에 시스템 에러의 원인이 될 수 있는 경고성 메시지를 나타냅니다. |
info | 어떠한 상태 변경과 같은 정보성 메시지를 나타냅니다. |
debug | 개발 시에 디버그 용도로 사용하는 메시지입니다. |
trace | 디버그 레벨이 너무 광범위한 것을 해결하기 위해 좀 더 상세한 이벤트를 나타냅니다. |
마지막으로 로그의 타입에 대해 알아보도록 하겠습니다.
타입 | 설명 |
sqlonly | SQL을 로그로 남기며, Prepared Statement와 관련된 파라미터는 자동으로 변경되어 SQL을 출력합니다. |
sqltiming | SQL과 SQL 실행 시간(milliseconds 단위)을 출력합니다. |
audit | ResultSet을 제외한 모든 JDBC 호출 정보를 출력합니다. JDBC 관련 문제를 추적하는 경우를 제외하고는 사용이 권장되지 않습니다. |
resultset | ResultSet을 포함한 모든 JDBC 호출 정보를 출력합니다. |
resultsettable | SQL 조회 결과를 테이블 형태로 출력합니다. |
connection | Connection의 연결과 종료에 관련된 로그를 출력합니다. 커넥션 누수 문제 해결에 도움이 됩니다. |
반응형
'Programing' 카테고리의 다른 글
이클립스 Dynamic Web Project 없을 때 (1) | 2022.10.19 |
---|---|
CI/CD란 (1) | 2022.09.06 |
[ vscode ] .classpath가 안보일때 보이게 하는 방법 (0) | 2021.11.02 |
VScode 로 maven 프로젝트 생성 (0) | 2021.10.14 |
[ Golang ] 설치 (0) | 2021.10.06 |