OPEN HYPER STEP
← 목록으로 (Java+Spring)
JAVA · 31 / 69
java
CHAPTER 31 / 69
읽기 약 2
FUNCTION

로깅 설정


핵심 개념

Spring Boot는 SLF4J + Logback을 기본 사용한다.

@Slf4j (Lombok)으로 log 변수 자동 생성.

log.info, log.warn, log.error 레벨 구분 사용.

production에서는 FILE 어펜더로 로그를 파일에 저장한다.

코드 분석
JAVA📋 코드 (29줄)
import lombok.extern.slf4j.Slf4j;

@Slf4j  // Lombok - log 변수 자동 생성
@Service
public class UserService {

    public User findById(Long id) {
        log.info("사용자 조회 시작 - id: {}", id);

        try {
            User user = userRepository.findById(id)
                .orElseThrow(() -> new ResourceNotFoundException("User not found: " + id));

            log.info("사용자 조회 완료 - email: {}", user.getEmail());
            return user;

        } catch (ResourceNotFoundException e) {
            log.warn("사용자 없음 - id: {}", id);
            throw e;
        } catch (Exception e) {
            log.error("사용자 조회 오류 - id: {}, error: {}", id, e.getMessage(), e);
            throw e;
        }
    }
}

// application.properties 로그 레벨 설정
// logging.level.com.example=DEBUG
// logging.file.name=logs/app.log

AI 프롬프트
🤖 AI에게 잘 물어보는 법 — 모델·전략별 프롬프트
Claude

무료: Sonnet 4.6 / Pro $20/mo: Opus 4.6

이 Spring '로깅 설정' 코드에서
DI 관련 버그·순환 참조·트랜잭션 누수를
찾아서 수정해줘.
ChatGPT

무료: GPT-5.5 / Plus $20/mo: GPT-5.5 Pro

'로깅 설정'를 Spring Boot 3.x로 구현한
실전 API 코드(컨트롤러+서비스+레포지토리+테스트)를 완성형으로 만들어줘.
Gemini

무료: 2.5 Flash / Pro $19.99/mo: 3.1 Pro

이 Spring '로깅 설정' 프로젝트의 빈 구조와
의존성 트리를 전체 분석하고
N+1 쿼리·순환 참조·성능 병목을 정리해줘.
Grok

무료: Grok 4.1 / SuperGrok $30/mo

Spring '로깅 설정' vs Quarkus·Micronaut·Ktor의
동일 기능 구현을 2026년 한국 채용 시장 기준으로
솔직히 비교해줘.

⭐ 이것만 기억하세요
로깅 설정 이 3가지만 확실히 잡으세요
1.System.out.println으로 로깅하면 레벨 구분이 없고 파일 저장이 안 됩니다
2.SLF4J + Logback으로 로그 레벨(ERROR/WARN/INFO/DEBUG), 파일 저장, 일별 로테이션을 설정합니다
3.다음 챕터에서 코드가 의도대로 동작하는지 검증하는 테스트를 배웁니다


공유하기
진행도 31 / 69