Spring 컨테이너 (+ 싱글톤)
Spring 컨테이너
- Spring 컨테이너는 빈을 저장하기 위한 컨테이너라고 보면 됨
- 주로 AppConfig로서 작성이 됨
- 방식 -> XML , JAVA 코드, ... (여러 방법으로 AppConfig를 이룰 수 있음)
- ApplicationContext || BeanFactory 라고도 불리움
싱글톤
- 인스턴스를 1개를 만들어서 서로 공유하는 목적 ( 무분별한 인스턴스 생성을 방지할 수 있다)
- 생성방법
public class SingletonTest{
// 인스턴스 생성 (1개) -> 구체 클래스 (SingleTest)에 의존하게 됨
private static final SingletonTest instance = new SingletonTest();
private SingleTest(){}; // 생성자 막기
// 인스턴스 get
public static SingleTest getInstance(){
return this.instance;
}
}
- 싱글톤 문제점
- 싱글톤 패턴을 구현하는 코드가 많음
- 구체 클래스에 의존하게 됨 ( DIP 위반 : 인터페이스에 의존해야함)
- 클라이언트가 구체클래스에 의존하게 되어 OCP 원칙 위반 가능성 농후 ( 확장시에 , 클라이언트 코드도 수정 )
- 테스트하기 어려움
- private 생성자로 자식 클래스를 만들기 어려움
- 내부 속성을 변경하거나 초기화하기 어려움
싱글톤 컨테이너
- 싱글톤 컨테이너 (@Configuration AppConfig)에서는 스프링에서 빈을 싱글톤식으로 관리해줌
- 고객의 요청이 있을때마다, 생성하는 것이 아닌 이미 만들어진 객체를 공유함
싱글톤 사용시 주의할 점 (싱글톤 패턴 / 싱글톤 컨테이너)
- Stateful(상태 유지)하게 설계하면 안됨
- Stateless(무상태) 지향 설계
- 가급적 읽기 위주로 설계
- 필드 대신해서, 지역변수 | ThreadLocal | 파라미터 등을 사용해야함
- 지역변수 : 메서드 내에서만 호출되고 소멸됨
- Thread : 쓰레드는 독립적으로 실행되기에, 각 스레드마다 1개의 싱글톤 객체가 생성되서 관리됨
- 파라미터 : 파라미터로 값을 넘기기에, 필드를 사용하지 않아도 됨
public class StatefulTest {
private static StatefulTest instance = new StatefulTest();
private StatefulTest() {}
public static StatefulTest getInstance() {
return instance;
}
private int number; //멤버 필드
public void write(int number) {
this.number = number; // 외부 멤버필드 변경 (싱글톤 주의할 점)
}
public int getNumber() {
return number;
}
public static void main(String[] args) {
StatefulTest test1 = StatefulTest.getInstance();
StatefulTest test2 = StatefulTest.getInstance();
test1.write(100);
test2.write(200);
// test1 : 200 , test2: 200 의도와는 다르게 나옴
System.out.println("test1 : " + test1.getNumber() + " test2 : " + test2.getNumber());
}
}
싱글톤 컨테이너 (@Configuration / @Bean)
- @Configuration
- 해당 어노테이션은 스프링에서 해당 클래스가 Config파일을 인지할 수 있게 해줌 ( 싱글톤 컨테이너 인식)
- 해당 어노테이션이 Bean을 싱글톤으로 관리할 수 있게 기능함
@Bean
public BeanTest beanTest(){
if (beanTest가 이미 스프링컨테이너에 등록)
return 스프링컨테이너에서 찾아서 반환;
else
// 스프링 컨테이너에 빈 등록
return 해당 bean 반환
}
- @Bean
- 스프링컨테이너 내부에 빈 생성
- 싱글톤으로 관리되는 것과는 무관