inflearn logo
강의

강의

N
챌린지

챌린지

멘토링

멘토링

N
클립

클립

로드맵

로드맵

지식공유

스프링 핵심 원리 - 고급편

스프링 AOP 구현6 - 어드바이스 종류

LogTrace, AopConfig 순환 참조..

514

jhahn

작성한 질문수 4

0

안녕하세요. 제가 아래 코드 처럼 개인 프로젝트에 로그를 추가해보고 싶어 빈으로 등록 했습니다.

@Configuration
public class LogConfig {
    @Bean
    public LogTrace logTrace() {
        return new ThreadLocalLogTrace();
    }
}
@Slf4j
@Aspect//ㅇㅓ드바이저로 변환하여 저장(어드바이저 빌더)
public class LogTraceAspect {
    //어드바이스 로직
    private final LogTrace logTrace;

    public LogTraceAspect(LogTrace logTrace) {
        this.logTrace = logTrace;
    }
}
@Configuration
public class AopConfig {

    @Bean
    public LogTraceAspect logTraceAspect(LogTrace logTrace) {
        return new LogTraceAspect(logTrace);
    }
}

┌─────┐

| logTraceAspect defined in class path resource [co/kr/***/cofig/aop/AopConfig.class]

↑ ↓

| logTrace defined in class path resource [co/kr/****/cofig/log/LogConfig.class]

└─────┘

이렇게 순환 참조 에러가 나더라구요..log와 aop에서 서로 참조하고 있는데 어떻게 설계를 해야 할지 감이 잘 안옵니다.

빈을 아래와 같이 한 곳에 모아두면 잘 동작 하지만 왜 동작 하는지 이해가 안되며 이렇게 해도 되는지 모르겠습니다.

@Configuration
public class AopConfig {

    @Bean
    public LogTraceAspect logTraceAspect(LogTrace logTrace) {
        return new LogTraceAspect(logTrace);
    }

    @Bean
    public LogTrace logTrace() {
        return new ThreadLocalLogTrace();
    }
}

혹시 더 좋은 방법이 있을까요??

감사합니다.

spring 디자인-패턴

답변 1

1

김영한

안녕하세요. jhahn님

이러한 설정 클래스는 AOP의 대상이 되지 않도록 설정하시는 것이 좋습니다.

패키지 위치를 적절하게 조정하고 서로의 설정 클래스가 대상이 되지 않도록 조정해주세요.

감사합니다.

SpringBoot 4.0.6 버전에서 PackageLogTracePostProcessor exception

0

90

3

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

0

75

1

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

0

103

2

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

0

74

1

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

0

70

1

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

0

64

1

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

0

84

1

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

1

423

2

final 키워드 사용 관련 질문

0

85

1

안녕하세요

0

78

1

ThradLocal 실무 사례

0

109

2

실무에서의 동시성 문제

0

73

1

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

0

63

1

ProceedingJoinPoint와 MethodInvocation에 대하여

0

81

1

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

0

86

1

안녕하세요 질문있습니다

0

49

1

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

0

47

1

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

0

87

1

순환참조

0

174

2

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

0

84

1

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

0

85

1

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

0

102

1

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

0

122

2

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

0

78

1