인프런 커뮤니티 질문&답변

김영균님의 프로필 이미지

작성한 질문수

스프링 입문 - 코드로 배우는 스프링 부트, 웹 MVC, DB 접근 기술

AOP 적용

aop 실행시 오류

작성

·

307

·

수정됨

0

학습하는 분들께 도움이 되고, 더 좋은 답변을 드릴 수 있도록 질문전에 다음을 꼭 확인해주세요.

1. 강의 내용과 관련된 질문을 남겨주세요.
2. 인프런의 질문 게시판과 자주 하는 질문(링크)을 먼저 확인해주세요.
(자주 하는 질문 링크: https://bit.ly/3fX6ygx)
3. 질문 잘하기 메뉴얼(링크)을 먼저 읽어주세요.
(질문 잘하기 메뉴얼 링크: https://bit.ly/2UfeqCG)

질문 시에는 위 내용은 삭제하고 다음 내용을 남겨주세요.
=========================================
[질문 템플릿]
1. 강의 내용과 관련된 질문인가요? (예/아니오)
2. 인프런의 질문 게시판과 자주 하는 질문에 없는 내용인가요? (예/아니오)
3. 질문 잘하기 메뉴얼을 읽어보셨나요? (예/아니오)

[질문 내용]
The dependencies of some of the beans in the application context form a cycle:

memberController defined in file [C:\MyJava\study\hello-spring\out\production\classes\hello\hello_spring\controller\MemberController.class]

memberService defined in class path resource [hello/hello_spring/service/SpringConfig.class]

┌─────┐

| timeTraceAop defined in class path resource [hello/hello_spring/service/SpringConfig.class]

└─────┘

이렇게 오류가 납니다

의존하는게 서로 겹친건지

수업과 똑같이 해도 오류나는 이유를 모르겠네요

https://drive.google.com/file/d/1UAbLzMZ1jvYSh7vWVDv0XIwgat0giIVu/view?usp=drive_link

답변 1

0

안녕하세요, 인프런 AI 인턴입니다. 김영균님의 질문과 관련하여 AOP 관련 순환 참조 오류 문제에 대해 다룬 유사한 사례를 찾았습니다. 김영균님께서 직면하신 문제에 대한 해결책을 제공하거나 유용한 정보를 얻을 수 있는 글입니다.

관련 질문:

이 질문에서는 AOP를 적용할 때 @Component 어노테이션 대신 SpringConfig@Bean으로 등록할 경우 순환 참조 오류가 발생하는 상황에 대해 설명하고 있습니다. 김영한 강사님께서 직접 답변하신 내용에는 순환 참조 오류가 발생하는 원인과 이를 해결할 수 있는 방법이 자세히 설명되어 있습니다.

답변에 따르면, @Around 어노테이션으로 지정된 AOP 대상이 SpringConfig의 빈 생성 메서드까지 포함되어 순환 참조 문제가 발생한다고 합니다. 이 문제를 해결하려면 AOP 대상에서 SpringConfig를 제외하는 방법을 사용할 수 있습니다.

이 정보가 김영균님의 현재 문제를 해결하는 데 도움이 되길 바랍니다. AOP 관련 순환 참조 오류는 설정이나 사용 방법에 따라 다양한 형태로 나타날 수 있기 때문에, 특정 상황에 맞는 해결 방법이 필요할 수 있습니다.

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

김영균님의 프로필 이미지
김영균
질문자

@Around("execution(* hello.hello_spring..*(..)) && !target(hello.hello_spring.SpringConfig)" )

SpringConfig를 설정하니 실행은 되지만
콘솔에 start, end가 출력되지 않습니다.

@Component 방식으로 등록하면 부팅시 콘솔창에 SpringConfig에 등록된 @Bean 메소드의 실행 시간이 Start, end 와 함께 출력되는데, 상기 해결책대로 @Bean 방식으로 등록하면 SpringConfig 클래스의 메소드는 제외되면서 부팅시에 메세지가 뜨지 않네요

저는 localhost:8080에 접속해서 회원 가입이나 목록 조회를 눌러 서비스 메소드를 실행시키면 정상적으로 start, end가 출력되네요