- 스프링은 태생이 기업용 온라인 서비스 기술을 지원하기 위해 탄생했습니다.
- 대부분의 스프링 애플리케이션은 웹 애플리케이션입니다. 물론 웹이 아닌 애플리케이션 개발도 얼마든지 개발할 수 있습니다.
- 웹 애플리케이션은 보통 여러 고객이 동시에 요청을 합니다.
스프링 없는 순수한 DI 컨테이너 테스트
public class SingletonTest {
@Test
@DisplayName("스프링 없는 순수한 DI 컨테이너")
void pureContainer() {
AppConfig appConfig = new AppConfig();
// 1. 조회: 호출할 때 마다 객체를 생성
MemberService memberService1 = appConfig.memberService();
// 2. 조회: 호출할 때 마다 객체를 생성
MemberService memberService2 = appConfig.memberService();
// 참조값이 다른 것을 확인
System.out.println("memberService1 = " + memberService1);
System.out.println("memberService2 = " + memberService2);
// memberService1 != memberService2
assertThat(memberService1).isNotSameAs(memberService2);
}
}
- 스프링 없는 순수한 DI 컨테이너인 AppConfig는 요청할 때 마다 객체를 새로 생성합니다.
- 고객 트래픽이 초당 100이 나오면 초당 100개 객체가 생성되고 소멸됩니다. => 메모리 낭비가 심합니다.
- 해결방안은 해당 객체가 딱 1개만 생성되고, 공유하도록 설계하면 됩니다. => 싱글톤 패턴
참조
'Spring' 카테고리의 다른 글
[스프링 핵심 원리 - 기본편] 싱글톤 컨테이너 (0) | 2021.09.17 |
---|---|
[스프링 핵심 원리 - 기본편] 싱글톤 패턴 (0) | 2021.09.17 |
[스프링 핵심 원리 - 기본편] 스프링 빈 설정 메타 정보 - BeanDefinition (0) | 2021.09.17 |
[스프링 핵심 원리 - 기본편] 다양한 설정 형식 지원 - 자바 코드, XML (0) | 2021.09.16 |
[스프링 핵심 원리 - 기본편] BeanFactory와 ApplicationContext (0) | 2021.09.15 |
댓글