inflearn logo
강의

Course

Instructor

Spring Core Principles - Advanced

Log Tracker V2 - Application

레벨이 감소하는 이유.

445

qheogus55

42 asked

1

beginSync() 안에 createNextLevel() 있어 레벨이 증가하는건 이해가 갑니다!  그런데 createPreviousLevel() 을 사용하지 않았는데 어떻게 레벨이 감소하는건가요?

로직 순서가

OrderControllerV2의 

1.trace.begin()

level:0

OrderServiceV2의

2.trace.beginSync()

level:1

OrderRepositoryV2의

3.trace.beginSync()

level:2

4.trace.end()

level:2

OrderServiceV2의

5.trace.end()

level: 1(?)

OrderControllerV2의 

6.trace.end()

level:0(?)

 

[7b341824] OrderController.request()

:id = 7b341824 level = 0

[7b341824] |-->OrderService.orderItem()

:id = 7b341824 level = 1

[7b341824] | |-->OrderRepository.save()

:id = 7b341824 level = 2

[7b341824] | |<--OrderRepository.save() time=1012ms

:id = 7b341824 level = 2

[7b341824] |<--OrderService.orderItem() time=1015ms

:id = 7b341824 level = ?

[7b341824] OrderController.request() time=1018ms

:id = 7b341824 level = ?

spring 디자인-패턴

Answer 2

4

yh

안녕하세요. qheogus55님

trace.begin()을 호출하면 status를 반환해주는데요.

trace.end()를 호출할 때 여기에 들어있는 값을 사용하기 때문입니다.

감사합니다.

0

myrhymetree8288

증가 할때는 TraceId의 필드를 이용,
감소 할때는 각 계층별 status 지역변수의 상태값 이용.

이렇게 이해하면 될까요?

0

yh

안녕하세요. 박성준님

생각하신 내용이 맞습니다.

감사합니다.

0

power1004pow

이 분 createPreviousId 리턴에 level 그냥 반환하거나 + 1 해놓으셨을 듯

0

arcsupark8350

createPreviousId 메서드는 사용하지 않아요

그냥 만들어 두신 거에요...

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

0

50

1

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

0

77

2

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

0

49

1

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

0

53

1

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

0

55

1

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

0

74

1

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

1

336

2

final 키워드 사용 관련 질문

0

74

1

안녕하세요

0

63

1

ThradLocal 실무 사례

0

97

2

실무에서의 동시성 문제

0

62

1

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

0

50

1

ProceedingJoinPoint와 MethodInvocation에 대하여

0

66

1

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

0

69

1

안녕하세요 질문있습니다

0

43

1

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

0

37

1

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

0

74

1

순환참조

0

158

2

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

0

77

1

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

0

73

1

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

0

86

1

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

0

115

2

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

0

66

1

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

0

69

2