인프런 커뮤니티 질문&답변

도토리님의 프로필 이미지
도토리

작성한 질문수

스프링 핵심 원리 - 고급편

로그 추적기 V1 - 적용

try문 안에 trace.begin() 넣기

작성

·

300

0

OrderControllerV1.java

@GetMapping("/v1/request")
public String request(@RequestParam String itemId) {

    TraceStatus status = trace.begin("OrderController.request()"); //시작 로그 출력
    try {
        orderService.orderItem(itemId);
        trace.end(status); //종료 로그 출력1
        return "ok";
    } catch (IllegalStateException e) {
        trace.exception(status, e); //종료 로그 출력2
        throw e;
    }
}

trace.begin() 코드에서도 예외가 발생할 수 있으니 try문에 넣어야 한다고 하셨는데, 어떤 부분에서 예외가 발생하나요..?? 혹시 log.info()에서 예외가 발생하나요??

답변 1

0

안녕하세요. 도토리님, 공식 서포터즈 OMG입니다.

영한님이 말씀하신 의도는 로그추적기라는 애플리케이션의 기능 흐름상 추적의 기능이 시작하는 부분에서 부터 추적 기능이 끝나는 일련의 흐름과정 중 시작 부분에서 .begin()을 호출했을 때 발생하는 예외를 처리해야 논리적인 애플리케이션 흐름에 맞기 때문에 try 내에서 호출하도록 하신 것으로 이해하시면 될 것 같습니다.

 

@Slf4j의 log.info 자체에서는 오류가 발생하지 않겠지만, log.info()를 사용하여 호출하는 부분에서 (가령 본 강의에서 addSpace에서 일련의 문제로 오류) 예외가 발생한다면 그것을 처리하기 위한 것입니다.

감사합니다.

도토리님의 프로필 이미지
도토리

작성한 질문수

질문하기