Development/Spring Boot

[Spring Boot] Bean factory와 ApplicationContext (중요)

sky Jeong 2022. 8. 14. 20:36

1- BeanFactory

  • 스프링 컨테이너의 최상위 인터페이스
  • 스프링 빈을 관리하고 조회하는 역할을 담당
    getBean(  ) 제공
  • 지금까지 우리가 사용했던 대부분의 기능은 BeanFactory가 제공하는 기능임

2- ApplicationContext

  • BeanFactory의 기능을 모두 상속 받아 제공
  • 빈을 관리하고 검색하는 기능을 BeanFactory가 제공하는데 둘의 차이는?
  • 애플리케이션 개발시 빈을 관리, 조회 기능은 물론이고 수 많은 부가기능이 필요함
    - BeanFactory 외에도 ApplicationContext는 다양한 인터페이스를 상속 받음
    - MessageSource, EnvironmentCapable, ApplicationEventPublisher, ResourceLoader, ...

    - MessageSource: 메시지 소스를 활용한 국제화 기능. [ ex. 한국에서 들어오면 한국어로, 영어권에서 들어오면 영어로 출력 ]
    - EnvironmentCapable: 환경 변수. 로컬, 개발(테스트 서버), 스테이징(운영과 가장 밀접), 운영(실제 프로덕션으로 나가는 것) 등 구분해 처리함. [ ex. 각 환경별로 어떤 DB에 연결해야할지와 같은 것을 처리함 ]
    - ApplicationEventPublisher: 애플리케이션 이벤트. 이벤트를 발행하고 구독하는 모델 편리하게 지원.
    - ResourceLoader: 편리한 리소스 조회. 파일, 클래스패스, 외부 등 리소스를 편리하게 조회.
  • 한 마디로, 
    일반적으로 애플리케이션 구현시 필요한 것과 BeanFactory를 합한 것이 ApplicationContext임

3- 정리

  • ApplicationContext는 BeanFactory의 기능을 상속 받음
  • ApplicationContext는 빈 관리 기능 + 편리한 부가 기능 제공
  • BeanFactory를 직접 사용할 일은 거의 없으며, 부가기능이 포함된 ApplicationContext를 사용
  • BeanFactory나 ApplicationContext를 스프링 컨테이너라 함