인프런 영문 브랜드 로고
인프런 영문 브랜드 로고

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

yoon6669님의 프로필 이미지

작성한 질문수

스프링 핵심 원리 - 기본편

@Configuration과 바이트코드 조작의 마법

@Configuration이 빈을 등록하는 것은 아닌게 맞나요?

작성

·

89

·

수정됨

1

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

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

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

[질문 내용]
아마 4. 스프링으로 전환하기 강의에서 설명하신 바에 따르면 스프링 빈을 생성하려 할 때

new AnnotationConfigApplicationContext(AppConfig.class) 해서 @Configuration을 기반으로 한 클래스를 인자로 전달하면, 이 클래스 내에 @Bean이 붙은 것들은 스프링 컨테이너에 빈으로 등록한다 라고 설명하셨는데요,

 

여태 @Configuration이 달린 AppConfig를 전달 해주었다면 이번 강의에서는 @Configuration을 삭제한 AppConfig를 전달 해주셨고 붙이지 않아도 @Bean이 붙은 객체들은 스프링 빈으로 다 등록된다고 하셨는데요.

 

그렇다면 @Configuration의 역할은 4. 스프링으로 전환하기에서 설명하셨던 것과 달리 @Configuration이 붙은 클래스내의 @Bean 붙은 것들을 스프링 빈으로 등록하도록 해주는 것이 아니라 @Bean은 @Configuration이 없어도 빈으로 등록되는 것이고 @Configuration의 역할은 그저 스프링 빈이 싱글톤임을 보장해주는 역할인 것인가요?

 

제가 기억한 앞선 강의와 살짝 달라진것 같아 헷갈리네요

답변 2

0

David님의 프로필 이미지

안녕하세요. yoon6669님, 공식 서포터즈 David입니다.

@Configuration 클래스의 경우 @Bean 메서드를 호출할 때 싱글톤이 반환되도록 보장합니다.

@Configuration과 무관하게 ApplicationContext의 Primary Source로 전달되는 것들은 스프링 빈으로 등록됩니다. new AnnotationConfigApplicationContext(AppConfig.class) 여기서 AppConfig.class가 Primary Source에 해당합니다.

@Configuration 클래스와 아닌 클래스가 모두 강의에서 다뤄지기 때문에 헷갈릴 수 있습니다.

위에 언급한 2가지를 분리해서 생각하셔야 합니다.

감사합니다.

yoon6669님의 프로필 이미지
yoon6669
질문자

감사합니다. 추가 질문 있습니다.

@Configuration을 빼도 스프링 빈으로 모두 등록 된다고 강의에서 설명하시는데요.

 

강의 12:20부터 보시면

주입된 MemberRepository 는 주입된 스프링 빈이 아니고 내가 직접 new MemoryMemberRespotory() 한 것과 동일하다. 스프링 컨테이너가 관리하지 않는 것이다 라고 설명하십니다.

 

여기서 헷갈리는게 @Configuration을 뺸 클래스를 등록해도 @Bean이 달린 클래스는 모두 스프링 빈으로 등록되는데 스프링 컨테이너가 관리하지 않는 다는 것은 그냥 빈으로 등록된 채로만 있는 것인가요?

 

그리고 10:30부터 보시면 AppConfig에서 memberRepository()가 여러번 호출되잖아요? 싱글톤이 깨졌다는 뜻이고. 강의에선 순수 자바코드가 실행되어 그렇다는데, 이때 각각의 MemoryMemberRepostory 객체도 매 호출된 것마다 빈에 등록되는건가요?

그러니 3개의 MemoryMemberRepostory 가 스프링 컨테이너에 등록되어있는걸까요?

@Configiration이 없어도 빈에 등록된다고 했으니 memberService, memberRepository, orderService 등이 빈에 등록되는 과정에서 각각 호출되는 memberRepository() MemoryMemberRepostory 객체도 빈에 등록되지 않을까라는 생각이어서요..

 

David님의 프로필 이미지

질문해 주신 부분은 스프링 컨테이너 내부 구현을 알아야 이해되는 부분이 있습니다.

 

간단히 설명드리면,

@Configuration이 없을 때, 빈 메타데이터에 등록된 팩토리 메서드로써 호출되는 경우에만 빈으로 등록됩니다. 이 경우 외에 호출될 때는 빈이 아닌 일반 객체입니다.

따라서, memberRepository()의 new MemberService(memberRepository())에서 memberRepository()가 호출되는 것은 후자에 해당하는 일반 객체입니다.

컨테이너가 빈을 생성 및 등록하기 위해 빈 메타데이터를 참조하여 팩토리 메서드로써 호출되는 memberRepository()에서 반환되는 객체가 빈으로 등록되게 됩니다.

yoon6669님의 프로필 이미지
yoon6669
질문자

답변 감사합니다. 해주신 답변과 더불어 다른 분들의 질답도 찾아보았는데요.

 

그렇다면 이 경우 총 3번의 memberRepository()로 생성되는 객체는 3가지이고,

이중 1가지는 스프링빈 객체(싱글톤)이고 나머지 두 객체는 순수 일반 MemberRepository객체가 맞나요?

David님의 프로필 이미지

네, 맞습니다.

강의 12분쯤부터 질문하신 내용에 대해 설명합니다.

0

인프런 AI 인턴님의 프로필 이미지

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

yoon6669님의 질문에 대해 답변드리겠습니다.

@Configuration 애노테이션의 역할과, 스프링 컨테이너에서의 빈 등록 과정에 대한 혼돈이 있으신 것 같습니다.

  1. @Configuration의 역할:

    • @Configuration 애노테이션이 붙은 클래스는 스프링 설정 클래스로 인식되며, 내부에 정의된 @Bean 메소드들이 스프링 빈으로 등록됩니다.
    • 가장 중요한 점은 @Configuration은 빈의 싱글톤을 보장하는 역할도 합니다. 이는 CGLIB라는 바이트코드 생성 라이브러리를 통해 프록시 객체를 생성하여 각 빈이 필요할 때 동일한 인스턴스를 반환하도록 보장합니다.
  2. @Configuration 없이 등록한 경우:

    • @Configuration 없이 @Bean을 사용하는 경우에도 빈은 등록되지만, 각 요청마다 새로운 인스턴스를 생성할 수 있습니다. 이는 즉, 싱글톤 보장이 되지 않습니다.
    • @Configuration이 없는 경우, 스프링은 프록시 클래스를 생성하지 않으므로, @Bean 메소드는 매번 새로운 객체를 반환할 수 있습니다.

이에 대한 더 많은 설명과 예시는 다음 링크에서 확인하실 수 있습니다: @Configuration 어노테이션 지정하는 이유

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

yoon6669님의 프로필 이미지

작성한 질문수

질문하기