inflearn logo
강의

Course

Instructor

Spring Core Principles - Advanced

Spring AOP Implementation 4 - Pointcut Reference

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

37

ggg7515

7 asked

0

[질문 템플릿]
1. 강의 내용과 관련된 질문인가요? (예)
2. 인프런의 질문 게시판과 자주 하는 질문에 없는 내용인가요? (예)
3. 질문 잘하기 메뉴얼을 읽어보셨나요? (예)

[질문 내용]
여기에 질문 내용을 남겨주세요.

 

aspect3 로 test 를 돌렸을 때 자꾸 트랜잭션 aop 가 먼저 실행 되길래 무엇이 잘못인지 보다가 doTransaction 이걸 -> dioTransaction 로 작성을 했길래 수정을 하고 실행 했더니 log 가 먼저 나오는걸 확인할수 있었습니다. 메서드 이름으로 실행 순서가 변경 되는 매커니즘도 있나요 ?

 

spring 디자인-패턴

Answer 1

0

communityai8509

안녕하세요, 인프런 AI 인턴입니다. ggg7515님.

스프링 AOP에서는 메서드 이름이 AOP의 실행 순서를 직접적으로 변경하지 않습니다. AOP 실행 순서는 주로 Aspect의 선언 순서와 여러 Aspect가 적용될 때의 우선순위 설정(@Order 어노테이션) 등에 의해 결정됩니다. 메서드명 변경으로 인해 AOP 동작이 달라졌다기보다는, 아마도 코드 변경 중에 다른 부분에서 오타나 문제점이 수정되어 원래의 순서대로 실행되는 것일 가능성이 큽니다.

관련된 질문과 답변도 참고하시면 도움이 될 것입니다:
- 12 쳅터 실전 예제 어드바이저 호출 순서 질문
- 섹션 8. @Aspect AOP의 강의에서 질문

이 두 게시물에서 AOP의 실행 순서와 그에 영향을 미칠 수 있는 요소에 대한 논의가 있으니 구체적인 코드와 함께 확인해보시면 좋을 것 같습니다.

저는 질문자님의 이해를 돕고자 지식공유자님의 기존 답변을 참고하여 유사한 답변 링크를 추천해드리고 있습니다. 현재 베타 기능으로 답변이 만족스럽지 않을 수 있는 점 양해 부탁드립니다. 🙏 추가적으로 궁금한 점이 있으시면, 이어서 질문해 주세요. 곧 지식공유자께서 답변해 주실 것입니다.

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

0

51

1

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

0

78

2

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

0

52

1

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

0

53

1

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

0

55

1

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

0

74

1

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

1

346

2

final 키워드 사용 관련 질문

0

75

1

안녕하세요

0

64

1

ThradLocal 실무 사례

0

97

2

실무에서의 동시성 문제

0

62

1

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

0

50

1

ProceedingJoinPoint와 MethodInvocation에 대하여

0

67

1

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

0

69

1

안녕하세요 질문있습니다

0

43

1

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

0

74

1

순환참조

0

158

2

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

0

77

1

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

0

75

1

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

0

88

1

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

0

117

2

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

0

67

1

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

0

73

2

빈으로 주입하지 않고 new로 객체 생성해도 되는데, 왜 ThreadLocal을 사용하나요?

0

72

1