본문 바로가기
Spring/spring 원리

빈 스코프

by 킹차니 2021. 6. 22.
김영한님의 인프런 강의와 PDF를 바탕으로 정리하였습니다.
https://www.inflearn.com/courses?s=%EA%B9%80%EC%98%81%ED%95%9C

 

 

 

빈스코프란?

스코프란 번역 그대로 빈이 존재할 수 있는 범위를 말한다.

 

스프링은 아래와 같은 다양한 스코프를 지원한다.

  • 싱글톤: 기본 스코프로 스프링 컨테이너의 시작과 종료까지 유지되는  가장 넓은 범위의 스코프이다.
  • 프로토타입: 스프링 컨테이너가 생성과 의존관계 주입까지만 관여하고 더는 관리하지 않는 매우 짧은 범위의 스코프.
  • 웹관련 스코프: 1. request: 웹요청이 들어올 때 생성되고, response로 나갈때까지 유지되는 스코프                                                                         2. sessoion: 웹 세션이 생성되고 종료될 때 까지 유지되는 스코프.                                                                                                   3. 웹의 서블릿 컨텍스트와 같은 범위로 유지되는 스코프.

 

 

특정 빈을 프로토타입 빈으로 지정할 경우 아래와 같이 한다.

1. 수동등록인 경우

   

2. 자동등록인 경우

 


 

 

스코프에 대한 테스트를 해보자.

 

1. 싱글톤 스코프 테스트

컨테이너에 등록된 SingletonBean이라는 빈 객체는 몇 번을 꺼내도 당연히 같은 빈일 것이다.

 

출력결과:

(추가로 컨테이너가 만들어지고, 빈을 생성하고, 의존관계를 주입한 후에 @PostConstruct가 붙은 init메소드가 실행된 것을 볼 수 있고, ac.close()로 어플리케이션 컨텍스트를 닫기 전에 @PrevDestroy가 붙은 destroy메소드가 실행되는 것을 볼 수 있다. )

 

싱글톤 빈 생성과정

1. 싱글톤 스코프의 빈을 스프링 컨테이너에 요청한다.

2. 스프링 컨테이너는 본인이 관리하는 스프링 빈을 반환한다.

3. 이후에 스프링 컨테이너에 같은 요청이 와도 같은 객체 인스턴스의 스프링 빈을 반환한다.

 

 

 

 

 

2. 프로토타입 스코프 테스트

프로토타입 빈이 언제 생성되고, 두 개의 빈이 같은 빈인지 다른 빈인지 실행해보자.

 

출력결과:

위의 결과에서 알 수 있는 것:

1. 어플리케이션 컨텍스트를 생성하고, 

    System.out.println("find prototypeBean1");

     init메서드보다 위의 출력문이 먼저 출력되는 것으로 보아 프로토타입 빈은 어플리케이션 컨텍스트를 생성한 시기에 만들어지는 것이 아       님을 알 수 있다. 또한 

2. prototypeBean1과 prototypeBean2의 참조값이 다른 것을 보아, 프로타입 빈은 싱글톤으로 관리되는 것이 아님을 알 수 있다.

3. destroy메소드가 실행되지 않는 것을 보아 스프링 컨테이너는 프로타입 빈의 생성과 의존관계 주입까지만 관여하고 이후에는 관리하지      않는 것임을 알 수 있다.(스프링 컨테이너가 만들고 버린다.)

 

1. 프로토타입 스코프의 빈을 스프링 컨테이너에 요청한다.

2. 스프링 컨테이너는 이 시점에 프로토타입 빈을 생성하고, 필요한 의존관계를 주입한다.

3. 스프링 컨테이너는 생성한 프로토타입 빈을 클라이언트에 반환한다.

4. 이후에 스프링 컨테이너에 같은 요청이 오면 항상 새로운 프로토타입 빈을 생성해서 반환한다.

 

스프링 컨테이너는 프로토타입 빈을 생성하고, 의존관계 주입, 초기화까지만 처리한다는 것.

클라이언트에 빈을 반환하고, 이후 스프링 컨테이너는 생성된 프로토타입 빈을 관리하지 않는다.

프로토타입 빈을 관리할 책임은 프로토타입 빈을 받은 클라이언트에 있다.

그래서 @PreDestory 같은 종료 메서드가 호출되지 않는다.

 

 

프로토타입 빈 정리:

  • 스프링 컨테이너에 요청할 때마다 새로 생성된다.
  • 스프링 컨테이너는 프로토타입 빈의 생성과 의존관계 주입 그리고 초기화까지만 관여한다.
  • 종료 메서드가 호출되지 않는다.
  • 그래서 프로토타입 빈은 프로토타입 빈을 조회한 클라이언트가 관리해야 한다.
  • 종료 메서드에 대한 호출도 클라이언트가 직접 해야한다.