LogTrace, AopConfig 순환 참조..
514
작성한 질문수 4
안녕하세요. 제가 아래 코드 처럼 개인 프로젝트에 로그를 추가해보고 싶어 빈으로 등록 했습니다.
@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();
}
}혹시 더 좋은 방법이 있을까요??
감사합니다.
답변 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





