스프링 컨테이너와 스프링 빈

Yeseong31·2023년 10월 7일
0

스프링 컨테이너

ApplicationContext applicationContext
		= new AnnotationConfigApplicationContext(AppConfig.class);
  • ApplicationContext를 스프링 컨테이너라고 한다.
  • 스프링 컨테이너는 XML, 애노테이션 등 다양한 설정 정보를 받아들이도록 설계되었다.
  • 스프링 컨테이너에 등록된 객체를 스프링 빈이라고 한다.

스프링 컨테이너의 생성 과정

  1. 스프링 컨테이너 생성

    • 스프링 컨테이너를 생성할 때에는 구성 정보를 지정해주어야 한다.
  2. 스프링 빈 등록

    • 스프링 컨테이너는 파라미터로 넘어온 설정 클래스 정보로 스프링 빈을 등록한다.
    • 스프링 빈 이름은 항상 다른 이름이어야 한다.
  3. 스프링 빈 의존 관계 설정

    • 스프링 컨테이너는 설정 정보를 참고하여 의존 관계를 주입한다.
    • 빈을 생성하고, 의존 관계를 주입하는 단계가 나뉘어 있다.

의존 관계 주입은 단순히 자바 코드를 호출하는 것이 아니다. ➡️ 싱글톤 컨테이너
스프링 빈을 등록하면 생성자 호출과 함께 의존 관계 주입도 한 번에 처리된다. ➡️ 의존 관계 주입


스프링 빈

스프링 빈은 스프링 IoC 컨테이너에 의해 관리되는 자바 객체(POJO)이다.

In Spring, the objects that form the backbone of your application and that are managed by the Spring IoC container are called beans. A bean is an object that is instantiated, assembled, and otherwise managed by a Spring IoC container.

  • 스프링이 제어 권한을 가져 직접 생성하고 관계를 부여하는 객체를 (Bean)이라고 한다.
  • 스프링 프레임워크는 “제어의 역전”“의존 관계 주입”으로 객체를 관리한다.
  • 이때 의존 관계 주입은 빈끼리만 가능하다.

자바 빈과 스프링 빈은 서로 다른 개념이다.
자바 빈은 DTO, VO 등 특정 형태의 클래스를 가리킨다. private으로 구성되어 getter/setter로만 접근할 수 있고, 전달 인자가 없는 생성자를 가지는 클래스이다. 반면 스프링 빈은 스프링 IoC 컨테이너가 관리하는 자바 객체이다.


BeanFactory

BeanFactory의 상속 관계
BeanFactory ⬅️ ApplicationContext ⬅️ AnnotationConfigApplicationContext

  • BeanFactory
    • 스프링 컨테이너의 최상위 인터페이스이다.
    • 스프링 빈을 관리하고 조회하는 역할을 한다.
    • getBean()을 제공한다.
  • ApplicationContext
    • BeanFactory의 기능을 모두 상속받아 제공한다.
    • ApplicationContext는 빈 관리 기능에 더해 편리한 부가 기능을 제공한다.
      • 메시지 소스를 활용한 국제화 기능
      • 환경 변수
      • 애플리케이션 이벤트
      • 리소스 조회

다양한 설정 형식 지원

스프링 컨테이너는 다양한 형식의 설정 정보를 받아들일 수 있도록 설계되어 있다.

애노테이션 기반

ApplicationContext applicationContext
		= new AnnotationConfigApplicationContext(AppConfig.class);
  • new AnnotationConfigApplicationContext(AppConfig.class)
  • AnnotationConfigApplicationContext 클래스를 사용하면서 자바 코드로 된 설정 정보를 넘기면 된다.

XML 기반

  • 컴파일 없이 빈 설정 정보를 변경할 수 있는 장점이 있다.
  • GenericXmlApplicationContext를 사용하면서 xml 설정 파일을 넘기면 된다.
  • 자세한 사항은 스프링 공식 레퍼런스 문서를 참고하자.

스프링 빈 설정 메타 정보

스프링은 BeanDefinition을 추상화하여 다양한 설정 형식을 지원한다.
쉽게 이야기해서 역할과 구현을 개념적으로 나눈 것으로 볼 수 있다.

  • BeanDefinition빈 설정 메타 정보이다.
    • @Bean, <bean> 당 각각 하나씩 메타 정보가 생성된다.
    • 스프링 컨테이너는 이 메타 정보를 기반으로 스프링 빈을 생성한다.
  • AnnotationConfigApplicationContextAnnotatedBeanDefinitionReader를 통해 AppConfig.class를 읽고, BeanDefinition을 생성한다.
  • 새로운 형식의 설정 정보가 추가되면 XxxBeanDefinitionReader를 만들어서 BeanDefinition을 생성하면 된다.

BeanDefinition 정보

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

BeanDefinition을 직접 생성해서 스프링 컨테이너에 등록할 수는 있지만, 잘 사용하지는 않는다. 다만 스프링이 다양항 형태의 설정 정보를 BeanDefinition으로 “추상화”한다는 점을 눈여겨 보자.


참고

[인프런] 스프링 핵심 원리 - 기본편

profile
역시 개발자는 알아야 할 게 많다.

0개의 댓글

관련 채용 정보