전체 글
-
[김영한 스프링] 13. 웹 애플리케이션과 싱글톤Spring/스프링 핵심 원리 - 기본편 2023. 4. 21. 01:28
웹 애플리케이션과 싱글톤 웹 애플리케이션은 보통 여러 고객이 동시에 요청한다. package hello.core.singletonTest; import hello.core.AppConfig; import hello.core.member.MemberService; import org.assertj.core.api.Assertions; import org.junit.jupiter.api.DisplayName; import org.junit.jupiter.api.Test; public class SingletonTest { @Test @DisplayName("스프링 없는 순수한 DI 컨테이너") void pureContainer() { AppConfig appConfig = new AppConfig(); //..
-
[김영한 스프링] 12. BeanFactory와 ApplicationContext, 다양한 설정 형식 지원, 스프링 빈 설정 메타 정보Spring/스프링 핵심 원리 - 기본편 2023. 4. 16. 23:31
1. BeanFactory와 ApplicationContext BeanFactory 스프링 컨테이너의 최상위 인터페이스다. 스프링 빈을 관리하고 조회하는 역할을 담당한다. getBean()을 제공한다. 지금까지 우리가 사용했던 대부분의 기능은 BeanFactory가 제공하는 기능이다. ApplicationContext BeanFactory 기능을 모두 상속받아서 제공한다. 빈을 관리하고 검색하는 기능을 BeanFactory가 제공해주는데, 그러면 둘의 차이가 뭘까? 애플리케이션을 개발할 때는 빈을 관리하고 조회하는 기능은 물론이고, 수많은 부가기능이 필요하다. 메시지 소스를 활용한 국제화 기능 예를 들어서 한국에서 들어오면 한국어로, 영어권에서 들어오면 영어로 출력 환경변수 로컬, 개발, 운영 등을 구분..
-
[김영한 스프링] 11. 스프링 빈 조회Spring/스프링 핵심 원리 - 기본편 2023. 4. 16. 21:23
1. 스프링 빈 조회 - 기본 스프링 컨테이너에서 스프링 빈을 찾는 가장 기본적인 조회 방법 ac.getBean(빈 이름, 타입) ac.getBean(타입) 조회 대상 스프링 빈이 없으면 예외 발생 test/java/hello.core/beanfind/ApplicationContextBasicFindTest 생성 빈 이름으로 조회 이름 없이 타입으로만 조회 구체 타입으로 조회 스프링 빈에 등록된 인스턴스 타입을 보고 결정하기 때문에 인터페이스(MemberService)가 아닌 구체화(MemberServiceImpl)로 적어도 됨 하지만 구체화로 적는 것은 안 좋음 '항상 역할과 구현은 구분해야 한다.', '역할에 의존해야 한다.'라고 했지만 구현에 의존한 것이기 때문에 안 좋음 실패 테스트 NoSuchB..
-
[김영한 스프링] 10. 스프링 컨테이너Spring/스프링 핵심 원리 - 기본편 2023. 4. 14. 22:41
스프링 컨테이너 생성 ApplicationContext applicationContext = new AnnotationConfigApplicationContext(AppConfig.class); ApplicationContext를 스프링 컨테이너라 한다. ApplicationContext는 인터페이스이다. 스프링 컨테이너는 XML을 기반으로 만들 수 있고, 애노테이션 기반의 자바 설정 클래스로 만들 수 있다. 직전에 AppConfig 를 사용했던 방식이 애노테이션 기반의 자바 설정 클래스로 스프링 컨테이너를 만든 것이다. 자바 설정 클래스를 기반으로 스프링 컨테이너(ApplicationContext)를 만들어보자. new AnnotationConfigApplicationContext(AppConfig.c..
-
[김영한 스프링] 09. 스프링으로 전환하기Spring/스프링 핵심 원리 - 기본편 2023. 4. 13. 01:43
@Configuration, @Bean 추가 스프링에서는 설정 정보에 @Configuration을 붙임 각 메서드에 @Bean을 추가하여 스프링 컨테이너에 등록됨 스프링 컨테이너 ApplicationContext를 스프링 컨테이너라 한다. 기존에는 개발자가 AppConfig를 사용해서 직접 객체를 생성하고 DI를 했지만, 이제부터는 스프링 컨테이너를 통해서 사용한다. 스프링 컨테이너는 @Configuration이 붙은 AppConfig를 설정(구성) 정보로 사용한다. 여기서 @Bean이라 적힌 메서드를 모두 호출해서 반환된 객체를 스프링 컨테이너에 등록한다. 이렇게 스프링 컨테이너에 등록된 객체를 스프링 빈이라 한다. 스프링 빈은 @Bean이 붙은 메서드의 명을 스프링 빈의 이름으로 사용한다. (memb..
-
[김영한 스프링] 08. 좋은 객체 지향 설계의 5가지 원칙 적용, IoC, DI, 그리고 컨테이너Spring/스프링 핵심 원리 - 기본편 2023. 4. 12. 22:04
좋은 객체 지향 설계의 5가지 원칙 적용 여기서 3가지 SRP, DIP, OCP 적용 SRP 단일 책임 원칙 한 클래스는 하나의 책임만 가져야 한다. 클라이언트 객체는 직접 구현 객체를 생성하고, 연결하고, 실행하는 다양한 책임을 가지고 있음 SRP 단일 책임 원칙을 따르면서 관심사를 분리함 구현 객체를 생성하고 연결하는 책임은 AppConfig가 담당 클라이언트 객체는 실행하는 책임만 담당 DIP 의존관계 역전 원칙 프로그래머는 "추상화에 의존해야지, 구체화에 의존하면 안 된다." 의존성 주입은 이 원칙을 따르는 방법 중 하나다. 새로운 할인 정책을 개발하고, 적용하려고 하니 클라이언트 코드도 함께 변경해야 했다. 왜냐하면 기존 클라이언트 코드(OrderServiceImpl)는 DIP를 지키며 Disc..
-
[김영한 스프링] 07. AppConfig 리팩터링, 새로운 구조와 할인 정책 적용Spring/스프링 핵심 원리 - 기본편 2023. 4. 12. 01:39
현재 AppConfig를 보면 중복이 있고, 역할에 따른 구현이 잘 안 보인다. 기대하는 그림 MemberRepository의 역할이 보여야 하는데 전혀 보이지 않음. 그래서 리팩터링 MemberRepository 생성 됨 package hello.core; import hello.core.discount.DiscountPolicy; import hello.core.discount.FixDiscountPolicy; import hello.core.member.MemberRepository; import hello.core.member.MemberService; import hello.core.member.MemberServiceImpl; import hello.core.member.MemoryMember..
-
[김영한 스프링] 06. 새로운 할인 정책 적용과 문제점, 관심사의 분리Spring/스프링 핵심 원리 - 기본편 2023. 4. 12. 00:47
할인 정책을 변경하려면 클라이언트인 OrderServiceImpl의 코드를 고쳐야 한다. 문제점 발견 우리의 역할과 구현을 충실하게 분리했다 -> OK 다형성도 활용하고, 인터페이스와 구현 객체를 분리했다. -> OK OCP, DIP 같은 객체지향 설계 원칙을 충실히 준수했다. -> 그렇게 보이지만 사실은 아니다. DIP : 주문서비스 클라이언트(OrderServiceImpl)는 DiscountPolicy 인터페이스에 의존하면서 DIP를 지킨 것 같은데? -> 클래스 의존관계를 분석해 보자. 추상(인터페이스) 뿐만 아니라 구체(구현) 클래스에도 의존하고 있다. 추상(인터페이스) 의존 : DiscountPolicy 구체(구현) 클래스 : FixDiscountPolicy, RateDiscountPolicy ..