컴포넌트 스캔과 의존관계 자동 주입 시작하기 지금까지 스프링 빈을 등록할 때는 자바 코드의 @Bean이나 XML의 등을 통해서 설정 정보에 직접 등 록할 스프링 빈을 나열했다. (이전 게시글 : 빈 등록) 더보기 xml로 빈등록 자바 코드로 빈등록 @Configuration public class AppConfig { @Bean public MemberService memberService() { return new MemberServiceImpl(memberRepository()); } @Bean public OrderService orderService() { return new OrderServiceImpl( memberRepository(), discountPolicy()); } @Bean pub..
spring
memberService → memberRepository() → MemoryMemberRepository() memberService 빈을 만드는 코드를 보면 memberRepository() 를 호출한다. 이 메서드를 호출하면 new MemoryMemberRepository() 를 호출한다. orderService → memberRepository() → MemoryMemberRepository() orderService 빈을 만드는 코드도 동일하게 memberRepository() 를 호출한다. 이 메서드를 호출하면 new MemoryMemberRepository() 를 호출한다. @Configuration public class AppConfig { @Bean public MemberService..
싱글톤 패턴이든, 스프링 같은 싱글톤 컨테이너를 사용하든, 객체 인스턴스를 하나만 생성해서 공유하는 싱글톤 방식은 여러 클라이언트가 하나의 같은 객체 인스턴스를 공유하기 때문에 싱글톤 객체는 상태를 유지(stateful)하 게 설계하면 안된다. ⭕ ⭐무상태(stateless) ⭐ 로 설계해야 한다!! ❌ 특정 클라이언트에 의존적인 필드가 있으면 안된다. ❌ 특정 클라이언트가 값을 변경할 수 있는 필드가 있으면 안된다. → 스프링 빈의 필드에 공유 값을 설정하면 정말 큰 장애가 발생할 수 있다!!! 가급적 읽기만 가능해야 한다. 필드 대신 자바에서 공유되지 않는, 지역변수, 파라미터, TreadLocal 등을 사용해야 한다. 상태를 유지할 경우 발생하는 문제점 예시 테스트 코드로 진행하겠다. Statefu..
스프링 컨테이너는 싱글톤 패턴의 문제(이전 포스트 참고)를 해결하면서, 객체 인스턴스를 싱글톤(1개만 생성)으로 관리한다. 싱글톤 패턴의 문제는 간단히 말하자면, 싱글톤 패턴을 구현하는 코드 자체가 많이 들어간다. 의존관계상 클라이언트가 구체 클래스에 의존한다. 등 여러개가 있다. 싱글톤 컨테이너 스프링 컨테이너는 싱글턴 패턴을 적용하지 않아도, 객체 인스턴스를 싱글톤으로 관리한다. 이전에는 아래 코드처럼 싱글톤을 생성해줬어야 했다. 더보기 https://sesam-dev.tistory.com/77 참고 package hello.core.singleton; public class SingletonService { // 1. static 영역에 객체를 딱 1개만 생성해둔다. private static fi..
싱글톤 패턴? 클래스의 인스턴스가 딱 1개만 생성되는 것을 보장하는 디자인 패턴이다. 그래서 객체 인스턴스를 2개 이상 생성하지 못하도록 막아야 한다. private 생성자를 사용해서 외부에서 임의로 new 키워드를 사용하지 못하도록 막아야 한다. Test 코드에서 진행한다. 싱글톤 패턴 적용 package hello.core.singleton; public class SingletonService { // 1. static 영역에 객체를 딱 1개만 생성해둔다. private static final SingletonService instance = new SingletonService(); // 2. public으로 열어서 객체 인스턴스가 필요하면 이 static 메서드를 통해서만 조회하도록 허용한다. ..
스프링없는 순수한 DI 컨테이너인 AppConfig는 요청할 때 마다 객채를 새로 생성한다. 예를 들어, 클라이언트 A, B, C가 MemberService를 요청하면 각자 3번 MemberServiceImpl를 요청하게 된다. 고객 트래픽이 초당 100이 나오면 초당 100개 객체가 생성되고 소멸된다! 메모리 낭비가 심하다. ▶ 해결방안 : 해당 객체가 딱 1개만 생성되고, 공유하도록 설계하면 된다. => 싱글톤 패턴 테스트 코드 import hello.core.AppConfig; import hello.core.member.MemberService; import org.junit.jupiter.api.DisplayName; import org.junit.jupiter.api.Test; import s..
스프링 빈 설정 메타 정보 - BeanDefinition 스프링은 어떻게 이런 다양한 설정 형식을 지원하는 것일까? 스프링 컨테이너는 왜 어노테이션을 활용한 자바코드(@bean)인지 xml로 빈을 등록한 건지 상관이 없는 걸까? 그 중심에는 BeanDefinition 이라는 추상화가 있다. 쉽게 이야기해서 역할과 구현을 개념적으로 나눈 것이다! XML을 읽어서 BeanDefinition을 만들면 된다. 자바 코드를 읽어서 BeanDefinition을 만들면 된다. 스프링 컨테이너는 자바 코드인지, XML인지 몰라도 된다. 추상화(역할)인 BeanDefinition을 사용하기 때문에, 오직 BeanDefinition만 알면 된다. BeanDefinition 을 빈 설정 메타정보라 한다. @Bean , 당 ..
다양한 설정 형식 지원 - 자바 코드, XML 스프링 컨테이너는 다양한 형식의 설정 정보를 받아드릴 수 있게 유연하게 설계되어 있다. 자바 코드, XML, Groovy 등등 애노테이션 기반 자바 코드 설정 사용 new AnnotationConfigApplicationContext(AppConfig.class) AnnotationConfigApplicationContext 클래스를 사용하면서 자바 코드로된 설정 정보를 넘기면 된다. xml 설정 사용 최근에는 스프링 부트를 많이 사용하면서 XML기반의 설정은 잘 사용하지 않는다. 아직 많은 레거시 프로젝트 들 이 XML로 되어 있고, XML을 사용하면 컴파일 없이 빈 설정 정보를 변경할 수 있는 장점이 있다. GenericXmlApplicationConte..
BeanFactory 스프링 컨테이너의 최상위 인터페이스 스프링 빈을 관리하고 조회하는 역할 getBean()을 제공 지금까지 우리가 사용했던 대부분의 기능은 BeanFactory가 제공하는 기능 ApplicationContext BeanFactory기능을 모두 상속받아서 제공 그럼 BeanFacotory와의 차이는?? 애플리케이션을 개발할 때는 빈을 관리하고 조회하는 기능 + 알파(수 많은 부가기능) ApplicationContext가 제공하는 부가기능 메시지소스를 활용한 국제화 기능(MessageSource) 예를 들어, 한국에서 들어오면 한국어로, 영어권에서 들어오면 영어로 출력 환경 변수EnvironmentCapable) 로컬, 개발, 운영 등을 구분해서 처리 애플리케이션 이벤트(Applicati..
전체코드 보기 더보기 package hello.core.beanfind; import hello.core.AppConfig; import hello.core.dicsount.DiscountPolicy; import hello.core.dicsount.FixDiscountPolicy; import hello.core.dicsount.RateDiscountPolicy; import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.DisplayName; import org.junit.jupiter.api.Test; import org.springframework.beans.factory.NoUniqueBeanDefinitionException; ..