작성
·
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에서 일련의 문제로 오류) 예외가 발생한다면 그것을 처리하기 위한 것입니다.
감사합니다.