Written on
·
90
·
Edited
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의 역할은 그저 스프링 빈이 싱글톤임을 보장해주는 역할인 것인가요?
제가 기억한 앞선 강의와 살짝 달라진것 같아 헷갈리네요
Answer 2
0
안녕하세요. yoon6669님, 공식 서포터즈 David입니다.
@Configuration 클래스의 경우 @Bean 메서드를 호출할 때 싱글톤이 반환되도록 보장합니다.
@Configuration과 무관하게 ApplicationContext의 Primary Source로 전달되는 것들은 스프링 빈으로 등록됩니다. new AnnotationConfigApplicationContext(AppConfig.class)
여기서 AppConfig.class가 Primary Source에 해당합니다.
@Configuration 클래스와 아닌 클래스가 모두 강의에서 다뤄지기 때문에 헷갈릴 수 있습니다.
위에 언급한 2가지를 분리해서 생각하셔야 합니다.
감사합니다.
질문해 주신 부분은 스프링 컨테이너 내부 구현을 알아야 이해되는 부분이 있습니다.
간단히 설명드리면,
@Configuration이 없을 때, 빈 메타데이터에 등록된 팩토리 메서드로써 호출되는 경우에만 빈으로 등록됩니다. 이 경우 외에 호출될 때는 빈이 아닌 일반 객체입니다.
따라서, memberRepository()의 new MemberService(memberRepository())에서 memberRepository()가 호출되는 것은 후자에 해당하는 일반 객체입니다.
컨테이너가 빈을 생성 및 등록하기 위해 빈 메타데이터를 참조하여 팩토리 메서드로써 호출되는 memberRepository()에서 반환되는 객체가 빈으로 등록되게 됩니다.
답변 감사합니다. 해주신 답변과 더불어 다른 분들의 질답도 찾아보았는데요.
그렇다면 이 경우 총 3번의 memberRepository()로 생성되는 객체는 3가지이고,
이중 1가지는 스프링빈 객체(싱글톤)이고 나머지 두 객체는 순수 일반 MemberRepository객체가 맞나요?
0
안녕하세요, 인프런 AI 인턴입니다.
yoon6669님의 질문에 대해 답변드리겠습니다.
@Configuration
애노테이션의 역할과, 스프링 컨테이너에서의 빈 등록 과정에 대한 혼돈이 있으신 것 같습니다.
@Configuration
의 역할:
@Configuration
애노테이션이 붙은 클래스는 스프링 설정 클래스로 인식되며, 내부에 정의된 @Bean
메소드들이 스프링 빈으로 등록됩니다.@Configuration
은 빈의 싱글톤을 보장하는 역할도 합니다. 이는 CGLIB라는 바이트코드 생성 라이브러리를 통해 프록시 객체를 생성하여 각 빈이 필요할 때 동일한 인스턴스를 반환하도록 보장합니다.@Configuration
없이 등록한 경우:
@Configuration
없이 @Bean
을 사용하는 경우에도 빈은 등록되지만, 각 요청마다 새로운 인스턴스를 생성할 수 있습니다. 이는 즉, 싱글톤 보장이 되지 않습니다.@Configuration
이 없는 경우, 스프링은 프록시 클래스를 생성하지 않으므로, @Bean
메소드는 매번 새로운 객체를 반환할 수 있습니다.이에 대한 더 많은 설명과 예시는 다음 링크에서 확인하실 수 있습니다: @Configuration 어노테이션 지정하는 이유
저는 질문자님의 이해를 돕고자 지식공유자님의 기존 답변을 참고하여 유사한 답변 링크를 추천해드리고 있습니다.
현재 베타 기능으로 답변이 만족스럽지 않을 수 있는 점 양해 부탁드립니다. 🙏
추가적으로 궁금한 점이 있으시면, 이어서 질문해 주세요. 곧 지식공유자께서 답변해 주실 것입니다.
감사합니다. 추가 질문 있습니다.
@Configuration을 빼도 스프링 빈으로 모두 등록 된다고 강의에서 설명하시는데요.
강의 12:20부터 보시면
주입된 MemberRepository 는 주입된 스프링 빈이 아니고 내가 직접 new MemoryMemberRespotory() 한 것과 동일하다. 스프링 컨테이너가 관리하지 않는 것이다 라고 설명하십니다.
여기서 헷갈리는게 @Configuration을 뺸 클래스를 등록해도 @Bean이 달린 클래스는 모두 스프링 빈으로 등록되는데 스프링 컨테이너가 관리하지 않는 다는 것은 그냥 빈으로 등록된 채로만 있는 것인가요?
그리고 10:30부터 보시면 AppConfig에서 memberRepository()가 여러번 호출되잖아요? 싱글톤이 깨졌다는 뜻이고. 강의에선 순수 자바코드가 실행되어 그렇다는데, 이때 각각의 MemoryMemberRepostory 객체도 매 호출된 것마다 빈에 등록되는건가요?
그러니 3개의 MemoryMemberRepostory 가 스프링 컨테이너에 등록되어있는걸까요?
@Configiration이 없어도 빈에 등록된다고 했으니 memberService, memberRepository, orderService 등이 빈에 등록되는 과정에서 각각 호출되는 memberRepository() MemoryMemberRepostory 객체도 빈에 등록되지 않을까라는 생각이어서요..