Spring

[Spring] BeanFactory와 ApplicationContext(스프링 컨테이너)

bum0w0 2024. 7. 20. 17:42

 BeanFactory

- 스프링 컨테이너의 최상위 인터페이스다.

- 스프링 빈을 관리하고 조회하는 대부분의 기능을 BeanFactory가 제공한다.

 

ApplicationContext

- BeanFactory를 확장한 인터페이스로 더 많은 부가기능을 제공한다.

- 국제화 기능, 환경변수 처리, 애플리케이션 이벤트 지원, 편리한 리소스 조회 등

 

 

보통 BeanFactory를 직접 사용하는 일은 거의 없고 편리한 부가기능이 포함된 ApplicationContext를 사용한다.

BeanFactory나 ApplicationContext를 스프링 컨테이너라고 부른다.

 


 

 

스프링 컨테이너를 만들 때는 어노테이션 기반 자바 코드로 설정 정보를 넘기거나 xml 설정 파일을 넘기는 방법이 있다.

 

어노테이션 기반 자바 코드 설정

// AppConfig 클래스를 사용하여 초기화
ApplicationContext ac = new AnnotationConfigApplicationContext(AppConfig.class);

 

XML 기반 설정

최근에는 스프링 부트를 사용하면서 xml 기반 설정은 잘 사용하지 않지만, 컴파일 없이 빈 설정 정보를 변경할 수 있는 장점이 있다.

public class XmlApplicationContext {
    @Test
    void xmlAppContext() {
    	// GenericXmlApplicationContext로 더 유연한 설정 접근 방식 사용도 가능
        ApplicationContext ac = new ClassPathXmlApplicationContext("AppConfig.xml");
        
        MemberService memberService = ac.getBean("memberService", MemberService.class);
        assertThat(memberService).isInstanceOf(MemberService.class);
    }
}

 

 

AppConfig.xml 파일 예시

<?xml version="1.0" encoding="UTF-8"?>
<beans xmlns="http://www.springframework.org/schema/beans"
       xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
       xsi:schemaLocation="http://www.springframework.org/schema/beans
                           http://www.springframework.org/schema/beans/spring-beans.xsd">

    <!-- 빈 정의 -->
    <bean id="memberService" class="hello.core.member.MemberServiceImpl"/>
         <constructor-arg name="memberRepository" ref="memberRepository" />
    </bean>

</beans>

 


 

스프링이 설정 방식을 다양하게 지원할 수 있는 이유는 무엇일까?

그것은 추상화된 BeanDefinition이라는 빈 설정 메타정보가 있기 때문이다. XML을 통해 BeanDefinition이 만들어지거나 자바 코드를 읽어서 BeanDefinition이 만들어질 수 있다. @Bean, <bean> 하나당 하나의 메타 정보가 생성된다.

 

스프링 컨테이너는 이 메타정보를 기반으로 스프링 빈을 생성하고 관리하게 되는 것이다.

 

 

BeanDefinition 정보 살펴보기

  • BeanClassName : 생성할 빈의 클래스 명(자바 설정처럼 팩토리 역할의 빈을 사용하면 없음)
  • factoryBeanName : 팩토리 역할의 빈을 사용할 경우 이름, 예) appConfig
  • factoryMethodName : 빈을 생성할 팩토리 메서드 지정, 예) memberService
  • Scope : 싱글톤(기본값)
  • lazyInit : 스프링 컨테이너를 생성할 때 빈을 생성하는 것이 아니라, 실제 빈을 사용할 때까지 최대한 생성을 지연처리 하는지 여부
  • InitMethodName : 빈을 생성하고, 의존관계를 적용한 뒤에 호출되는 초기화 메서드 명
  • DestoryMethodName : 빈의 생명주기가 끝나서 제거하기 직전에 호출되는 메서드 명
  • Constructor arguments, Properties : 의존관계 주입에서 사용한다. (자바 설정처럼 팩터리 역할의 빈을 사용하면 없음)

스프링이 다양한 형태의 설정 정보를 BeanDefinition으로 추상화해서 사용한다 정도로 이해하면 된다.

(BeanDefinition을 직접 생성해서 등록할 일은 거의 없다고 한다. 대신 전체적인 메커니즘을 떠올릴 수 있을 정도로 기억하면 될것같다.)

 

 

참고자료 : https://www.inflearn.com/course/스프링-핵심-원리-기본편