inflearn logo
강의

강의

N
챌린지

챌린지

멘토링

멘토링

N
클립

클립

로드맵

로드맵

지식공유

스프링 핵심 원리 - 고급편

AspectJ 동작원리 궁금

130

조성락

작성한 질문수 11

0

@Aspect
public class A{
  @Before("B.methodB()호출하기전에 적용")
  public Object lock(final ProceedingJoinPoint joinPoint) throws Throwable {
  }
}

public class B{
    private void methodB(){
    }
}

이런식으로 작성할 경우,
당연히 Before은 ProceedingJoinPoint를 사용할 수 없기때문에 lock이 호출이 안될겁니다.
그런데 왜 안되는지 궁금해서 한번 실행시켜봤는데,
스프링 실행 자체는 되나, 아무런 예외없이 정상적으로 lock함수를 호출하지 않더라고요
그래서 호출스택을 따라가보았더니, 아예 호출 자체를 안하는것을 확인 할 수 있었습니다.

그렇다면 왜그럴까 추측을 해보자면 아예 methodB에 프록시로 lock()을 등록하지 않은것일텐데(맞나요..?)
어디서 이와 관련된 처리를 하는지 찾다가 포기하고 질문을 올립니다.

AspectJProxyFactory에서 lock()을 advisor로 만드는것 까진 확인했으나,
이것을 어디서 활용하는지 모르겠네요 ㅠ

어떤 클래스를 보면 알수있다 정도로도 좋으니 혹시 아시는게 있다면 알려주시면 감사드리겟습니다.

spring 디자인-패턴

답변 1

0

인프런 AI 인턴

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

조성락님께서 질문하신 AspectJ 동작원리에 대해 답변드리겠습니다.

우선, @Before 어드바이스는 ProceedingJoinPoint를 지원하지 않기 때문에, ProceedingJoinPoint를 사용하는 방식으로는 적합하지 않습니다. 이는 @Around 어드바이스를 사용할 때 적합한 방식입니다. @Before 어드바이스는 타겟 메서드 실행 전에 특정 작업을 수행할 수 있지만, 타겟 메서드를 제어하거나 변경할 수는 없습니다.

해당 부분을 정리하자면, methodB가 호출되지 않는 이유는 해당 메서드가 private으로 정의되어 프록시를 통해 접근할 수 없기 때문입니다. 스프링 AOP는 기본적으로 프록시 기반의 AOP를 사용하며, 프록시는 public과 protected 메서드에만 적용할 수 있습니다. 따라서, private 메서드인 methodB에 어드바이스를 적용할 수 없습니다.

관련 처리를 담당하는 클래스 및 패키지를 몇 가지 추천드리자면:

  1. ProxyFactory: 스프링이 프록시를 생성하는데 사용하는 팩토리 클래스입니다.
  2. AdvisedSupport: 스프링 AOP 프록시 구성을 지원하는 클래스입니다.
  3. DefaultAopProxyFactory: 실제 AOP 프록시를 만드는 클래스입니다.

위 클래스를 살펴보시면 프록시 생성 및 어드바이스 적용 방식에 대한 이해를 높이는 데 도움이 될 것입니다.

보다 정확한 예제를 위해 methodB를 private이 아닌 public 형태로 수정한 뒤, @Around 어드바이스를 활용해보는 것을 권장드립니다.

추가로 관련된 코드를 참조하실 수 있도록 스프링 공식 문서나 스프링 AOP 관련 책자를 참고하시면 큰 도움이 될 것입니다.

관련 이미지

궁금하신 사항이 해결되었기를 바라며, 추가 질문은 언제든 환영입니다!

감사합니다.

원문 출처: AspectJ 관련 문서

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

0

52

1

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

0

79

2

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

0

53

1

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

0

53

1

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

0

56

1

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

0

74

1

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

1

351

2

final 키워드 사용 관련 질문

0

77

1

안녕하세요

0

64

1

ThradLocal 실무 사례

0

97

2

실무에서의 동시성 문제

0

62

1

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

0

50

1

ProceedingJoinPoint와 MethodInvocation에 대하여

0

67

1

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

0

69

1

안녕하세요 질문있습니다

0

44

1

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

0

38

1

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

0

74

1

순환참조

0

158

2

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

0

77

1

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

0

76

1

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

0

88

1

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

0

117

2

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

0

67

1

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

0

73

2