Bean 메타정보 관련 동작, 스프링 컨테이너에 등록되는 과정이 궁금합니다.
295
작성한 질문수 53
안녕하세요.
항상 양질의 답변 글을 달아주셔서 너무 감사합니다. 다름이 아니라 이전 강의를 복습하면서, 제가 궁금한 부분이 있어 질문 드리고 싶어 글을 적습니다.
Bean Definition을 통해서 스프링 컨테이너에 등록되는 과정이 궁금한데, 한번 이런 흐름으로 가는데 틀린 부분이 없는지 봐주실 수 있을까요?
전체 흐름이 맞는지, 그리고 각 과정에서 잘못 알고 있는 부분은 없는지 한번 알려주시면 감사하겠습니다.
1. 스프링부트가 시작되면 @Configuration이 붙은 AppConfig 클래스를 자동으로 스캔해서 스프링 컨테이너에 넣는다
2. 스프링 컨테이너, 여기서는 ApplicationContext의 구현체인 AnnotationApplicationContext가 AppConfig.class 정보를 AnnotatedReader를 통해서 읽은 다음 @Bean이 붙은 Bean Definition을 만든다.
3. 만들어진 Bean Definition을 AnnotationApplicationContext에서 읽어서 빈 객체를 생성해서 내부 빈 저장소에 저장한다. 이 때, 각 메서드는 @ComponentScan에서 생성자 주입과는 다르게 동작한다 (생성자 주입은 빈 객체를 생성하면서 의존관계 주입 설정 완료)
4. 의존관계 주입 단계에서 각 Bean Definition을 참고해서 Bean 간의 의존 관계를 설정해준다. 이 때, 생성 방식은 Bean Factory Interface의 구현체인 AnnotationContext로 했기 때문에 Bean Factory Method 방식으로 Bean Definition이 생성되었다.
앞뒤 내용을 조합해보면, 이렇게 될 것 같은데.. 혹시 틀린 부분이 없을지 같이 한번 봐주실 수 있으실까요?
항상 많은 가르침 주셔서 너무 감사합니다.
답변 1
2
안녕하세요. ...님, 공식 서포터즈 David입니다.
.
3. 만들어진 Bean Definition을 AnnotationApplicationContext에서 읽어서 빈 객체를 생성해서 내부 빈 저장소에 저장한다. 이 때, 각 메서드는 @ComponentScan에서 생성자 주입과는 다르게 동작한다 (생성자 주입은 빈 객체를 생성하면서 의존관계 주입 설정 완료)
=> @Autowired가 걸려있는 메서드는 빈 생성 이후 의존관계 주입이 발생하고 생성자의 경우 빈 생성과 동시에 의존관계 주입이 발생합니다.
4. 의존관계 주입 단계에서 각 Bean Definition을 참고해서 Bean 간의 의존 관계를 설정해준다. 이 때, 생성 방식은 Bean Factory Interface의 구현체인 AnnotationContext로 했기 때문에 Bean Factory Method 방식으로 Bean Definition이 생성되었다.
=> Bean Factory Method 방식이라하면 자바 설정 파일 내 @Bean이 붙은 메서드 정보를 읽어 Bean Definition을 생성하는 걸 말씀하시는건가요?
빈 생성 과정의 경우 "다양한 의존관계 주입 방법"편도 참고해주세요.
.
감사합니다.
0
좋은 답변 달아주셔서 감사합니다! 추가 질문이 있어서 글을 적습니다
3. 만들어진 Bean Definition을 AnnotationApplicationContext에서 읽어서 빈 객체를 생성해서 내부 빈 저장소에 저장한다. 이 때, 각 메서드는 @ComponentScan에서 생성자 주입과는 다르게 동작한다 (생성자 주입은 빈 객체를 생성하면서 의존관계 주입 설정 완료)
=> @Autowired가 걸려있는 메서드는 빈 생성 이후 의존관계 주입이 발생하고 생성자의 경우 빈 생성과 동시에 의존관계 주입이 발생합니다.
→ 이 경우에는 생성자처럼 보이는데 일반 메서드지 생성자가 아니지 않나요?
public MemberService MemberService(OrderService orderService, MemberRepository, memberRepository)
위의 코드가 영한님 강의에서 AppConfig에 있던 메서드였는데, public 앞에 return Type이 명시된 것으로 봐서, 생성자라기보다는 Class 명과 동일한 이름을 가지는 메서드로 보입니다. 그래서 생성자가 아니라, DI 의존관계 주입 단계에서 주입이 되는 걸로 이해를 했는데.. 혹시 저것도 생성자와 동일하게 동작하는 것으로 봐도 괜찮을까요?
4. 의존관계 주입 단계에서 각 Bean Definition을 참고해서 Bean 간의 의존 관계를 설정해준다. 이 때, 생성 방식은 Bean Factory Interface의 구현체인 AnnotationContext로 했기 때문에 Bean Factory Method 방식으로 Bean Definition이 생성되었다.
=> Bean Factory Method 방식이라하면 자바 설정 파일 내 @Bean이 붙은 메서드 정보를 읽어 Bean Definition을 생성하는 걸 말씀하시는건가요?
→ 넵 맞습니다! Bean Definition을 생성할 때 영한님께서 직접 생성하는 방법과 Bean Factory Method를 통해서 생성하는 방법이 있다고 말씀해주셨는데, 이렇게 이으면 될지... 긴가민가하네요!
항상 좋은 답변 감사드립니다.
1
위의 코드가 영한님 강의에서 AppConfig에 있던 메서드였는데, public 앞에 return Type이 명시된 것으로 봐서, 생성자라기보다는 Class 명과 동일한 이름을 가지는 메서드로 보입니다. 그래서 생성자가 아니라, DI 의존관계 주입 단계에서 주입이 되는 걸로 이해를 했는데.. 혹시 저것도 생성자와 동일하게 동작하는 것으로 봐도 괜찮을까요?
=> @Configuration AppConfig 클래스 내에서 @Bean이 붙어있던 일반 메서드였다면 말씀하신대로 의존관계 주입 단계에서 주입되는 게 맞습니다.
→ 넵 맞습니다! Bean Definition을 생성할 때 영한님께서 직접 생성하는 방법과 Bean Factory Method를 통해서 생성하는 방법이 있다고 말씀해주셨는데, 이렇게 이으면 될지... 긴가민가하네요!
=> 네, 만약 그렇게 말씀하셨다면 그렇게 Bean Definition을 생성하는게 맞습니다.
구현체가 동적으로 정해질 때, 팩토리 기법을 사용하나요?
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





