스프링 핵심 원리 - 기본편 - Section4

두두·2022년 10월 28일
0

자바스프링

목록 보기
4/4
post-thumbnail

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

  • 스프링 컨테이너란?
    스프링에서 자바 객체들을 관리하는 공간
    빈의 생성부터 소멸까지를 개발자 대신 관리해주는 곳
  • 빈(Bean)이란?
    스프링에서 자바 객체를 가리킴

1. 스프링 컨테이너 생성

2. 스프링 빈 등록

3. 스프링 빈 의존관계 설정 - 준비

4. 스프링 빈 의존관계 설정 - 완료

스프링 빈 조회

✅ 기본

ac.getBean(빈이름, 타입)
ac.getBean(타입)

단, 조회 대상 스프링 빈이 없으면 예외 발생

NoSuchBeanDefinitionException: No bean named 'xxxxx' available

✅ 동일한 타입이 둘 이상

타입으로 조회시 같은 타입의 스프링 빈이 둘 이상이면 오류 발생
→ 빈 이름 지정하기!

ac.getBeansOfType() //해당 타입의 모든 빈을 조회

✅ 상속관계

부모 타입 조회 ▶ 자식 타입도 함께 조회
즉, Object 타입으로 조회하면, 모든 스프링 빈을 조회할 수 있음!
(Object : 모든 자바 객체의 최고 부모)

BeanFactory와 ApplicationContext

  • BeanFactory
    - 스프링 컨테이너의 최상위 인터페이스
    - 스프링 빈을 관리 및 조회하는 역할
    - getBean() 제공

  • ApplicationContext
    - BeanFactory 기능을 모두 상속받아서 제공
    + 편리한 부가 기능

📌 ApplicationContext의 추가기능

1. 메시지소스를 활용한 국제화 기능
2. 환경변수
3. 애플리케이션 이벤트
4. 편리한 리소스 조회

다양한 설정 형식 지원 - 자바 코드, XML

스프링 컨테이너는 다양한 형식의 설정 정보를 받아드릴 수 있도록 유연하게 설계됨!

  1. 애노테이션 기반 자바 코드 설정
    • 지금까지 쓰던 것!
  2. XML 설정
    • 최근에는 많이 안씀
    • 그치만, 아직 많은 레거시 프로젝트 들이 XML로 되어 있음
      + 컴파일 없이 빈 설정 정보를 변경할 수 있는 장점 有

스프링 빈 설정 메타 정보 - BeanDefinition

스프링이 다양한 설정 형식을 지원할 수 있는 이유!!

역할과 구현을 개념적으로 나눈 것

→ 스프링 컨테이너는 자바 코드인지, XML인지 몰라도 OK. BeanDefinition만 알면 됨

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

profile
멋쟁이가 될테야

0개의 댓글