inflearn logo
강의

강의

N
챌린지

챌린지

멘토링

멘토링

N
클립

클립

로드맵

로드맵

지식공유

스프링 핵심 원리 - 기본편

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

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

165

yoon6669

작성한 질문수 90

1


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

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

 

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

 

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

 

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

spring 객체지향

답변 2

0

David

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

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

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

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

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

감사합니다.

0

yoon6669

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

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

 

강의 12:20부터 보시면

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

 

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

 

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

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

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

 

0

David

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

 

간단히 설명드리면,

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

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

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

0

yoon6669

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

 

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

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

0

David

네, 맞습니다.

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

0

인프런 AI 인턴

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

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

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

  1. @Configuration의 역할:

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

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

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

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

구현체가 동적으로 정해질 때, 팩토리 기법을 사용하나요?

0

49

2

MemberService의 인터페이스를 왜 사용하는지 궁금합니다.

0

72

1

롬복 @Setter를 써야 하는 상황이 있는건가요?

0

87

1

빈 등록 메서드의 파라미터가 빈이 아니어도 되나요?

0

79

1

테스트 속도가 나중에 영향이 있을까요?

0

75

1

gradle 설정 안떠서 질문 남깁니다!

0

116

2

build.gradle로 프로젝트를 여는 이유

0

81

1

provider 사용하는 이유

0

85

1

다음 강의 뭘 들어야 할까요

0

123

2

프로토타입 빈, 직접 destroy 호출 안 할 경우

0

62

1

beanB

0

79

2

퀴즈다시풀기

0

63

1

Gradle로 바꿔도 오류가 똑같이 발생하네요 ㅠㅠ

0

90

2

"중복 등록과 충돌" 강의에서 강사님과 다른 에러가 발생합니다.

0

63

3

run 실행했는데 결과창이 이렇게 뜨네요 왜 그런건가요>

0

102

2

도메인의 정의?

0

57

1

ApplicationContext 질문입니다.

0

60

1

@Scope의 proxyMode를 사용할때 단위 테스트 방법

0

86

2

ai api 선정하기 관련 질문

0

115

2

생성자 자동주입 관련해서

0

60

1

생성자 직접 호출 vs 팩토리 메서드 패턴

0

93

2

Spring에서 SessionScope와 RequestScope는 함께 사용되나요?

1

63

1

12:25

0

75

2

appConfig.xml 오류

0

127

1