inflearn logo
강의

강의

N
챌린지

챌린지

멘토링

멘토링

N
클립

클립

로드맵

로드맵

지식공유

스프링 핵심 원리 - 고급편

로그 추적기 V1 - 적용

try문 안에 trace.begin() 넣기

391

도토리

작성한 질문수 92

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()에서 예외가 발생하나요??

spring 디자인-패턴

답변 1

0

OMG

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

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

 

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

감사합니다.

어드바이스 순서 디폴트 기준이 궁금합니다.

0

55

1

AspectV1 예제를 @Configuration 수동 등록으로도 가능한가요?

0

81

2

구체 클래스를 상속받아 확장한 형태도 클래스패턴/데코레이터 패턴이라고 칭하나요?

0

57

1

TraceTemplate 을 미리 빈으로 등록해서 사용할때 이렇게 설정하는게 맞는건가요?

0

54

1

Decorator 에서 추상메서드로 뺄때 질문 있습니다.

0

56

1

대상 클래스에 기본 생성자가 없을 때

0

76

1

스프링 부트 버전 4.0 aop 의존성 명칭 변경

1

362

2

final 키워드 사용 관련 질문

0

78

1

안녕하세요

0

65

1

ThradLocal 실무 사례

0

98

2

실무에서의 동시성 문제

0

64

1

로그 등 부가 기능에 대한 테스트코드

0

50

1

ProceedingJoinPoint와 MethodInvocation에 대하여

0

67

1

실무 멀티스레딩에 대한 궁금증

0

70

1

안녕하세요 질문있습니다

0

45

1

AspectV3 aop 실행 순서 문의 드립니다

0

38

1

MDC vs AOP 중에 고민중입니다.

0

76

1

순환참조

0

161

2

this를 단독으로 사용할때랑 파라미터 바인딩 할때 차이

0

78

1

빈 후처리에 등록 질문 있습니다.

0

77

1

AppConfig 설정하는 설명중에 이해가 안되는게 있습니다.

0

90

1

ThreadLocal을 지역변수로 선언하면 remove가 필요할까요?

0

118

2

@Aspect 어노테이션으로 생성된 Advisor의 Bean 저장 여부

0

69

1

ThreadLocal 사용시 부작용이 있을수 있을까요? (ThreadLocal.remove()를 잘한다고 해도..)

0

73

2