해당 타입의 스프링 빈이 다 필요한 경우도 있다. 예를 들어서 할인 서비스를 제공하는데, 클라이언트가 할인의 종류(rate, fix)를 선택할 수 있다고 가정해보자. 스프링을 사용하면 소위 말하는 전략 패턴을 매우 간단하게 구현할 수 있다. 예제설명 더보기 package hello.core.autowired; import hello.core.AutoAppConfig; import hello.core.discount.DiscountPolicy; import hello.core.member.Grade; import hello.core.member.Member; import org.junit.jupiter.api.Test; import org.springframework.context.ApplicationCo..
공부
@Qualifier("mainDiscountPolicy") 이렇게 문자를 적으면 컴파일시 타입 체크가 안된다. 다음과 같은 애노 테이션을 만들어서 문제를 해결할 수 있다. Annotation 직접 만들기 순서1. 자바 클래스를 어노테이션으로 생성해준다. 순서2. @Qualifier를 Annotation으로 만들 것이기 때문에 @Qualifier에 들어가서 위에 부분을 복사해온다. 순서3. 만들고자 했던 Annotation인 @MaindiscountPolicy에 붙여넣는다. @Qualifier도 사용할 것이기 때문에 추가해준다. package hello.core.annotataion; import org.springframework.beans.factory.annotation.Qualifier; impor..
문제 발생 - 조회 빈이 2개 이상 @Autowired 는 타입(Type)으로 조회 @Autowired // DiscountPolicy 타입으로 조회 private DiscountPolicy discountPolicy 타입으로 조회하기 때문에, 마치 다음 코드와 유사하게 동작한다. (실제로는 더 많은 기능을 제공한다.) ac.getBean(DiscountPolicy.class) 타입으로 조회하면 선택된 빈이 2개 이상일 때 문제가 발생 DiscountPolicy타입에 2개의 빈이 등록되어 있다. @Component public class FixDiscountPolicy implements DiscountPolicy {} @Component public class RateDiscountPolicy impl..
12Factors +3 https://12factor.net/ Cloud Native Application 개발 하거나 서비스를 운영할 때 사용되는 항목들 BASE CODE 자체 레퍼 지토리에 저장된 각 마이크로 서비스에 대한 단일 코드 베이스, 버전을 관리하기 위한 목적이고 형상관리를 위해 코드를 한 곳에서 배포하기 위한 목적, 코드의 통일적 관리 DEPENDENCY ISOLATION(종속성) 마이크로서비스는 자체 종속성을 가지고 패키지 되어 있다. 전체 시스템에 영향을 주지 않고 변경되 고 수정 될 수 있어야 한다. CONFIGRATIONS(구성정보) 시스템 내부가 아닌 시스템 코드 외부에서 구성관리 도구를 통해서 마이크로서비스에 필요한 작업들을 지원 하는 것. 동일한 배포가 올바르게 구성된 환경에 ..
클라우드 네이티브 아키텍처에 의해 설계되고 구현되는 어플리케이션을 클라우드 네이티브 어플리케이션(Cloud Native Application)이다. 클라우드 네이티브 어플리케이션(Cloud Native Application)은 아키텍처의 특징이나 안티프레자일와 같은 특징을 가지고 다음과 같은 형태로 구현된다. 클라우드 네이티브 어플리케이션(Cloud Native Application) 특징 1. MicroServices 2. CI/CD CI(Continuous Integration, 지속적인 통합) 통합 서버, 소스 관리(SCM), 빌드 도구, 테스트 도구 ex) Jenkins, Team CI, Travis CI CD(지속적인 배포) CD에는 두 가지 의미가 포함되어 있다. 패키지화 된 형태의 결과물을 ..
기존의 로컬 환경이나 사내에서 구축하고 운영하였던 시스템을 클라우드 환경으로 전환하기 위해서 어떤 아키텍처를 가져야 하는지 알아보자. Cloud Native Architecture(클라우드 네이티브 아키텍쳐)의 특징 1. 확장 가능한 아키텍처 시스템의 수평적 확장에 유연 → 더 많은 사용자 요청 처리 가능 확장된 서버로 시스템의 부하 분산, 가용성 분산 시스템 확장은 scale-up, scale-out으로 나눌 수 있다. scale-up : 하드웨어의 사양을 높이는 작업 ex) 가지고 있는 시스템의 CPU나 메모리의 스펙을 높이는 작업(scalse-up) 등 scale-out : 같은 사양의 서버 즉 인스턴스를 여러 개 배치함으로써 동시에 더 많은 요청을 처리할 수 있도록 하는 것 이렇게 시스템을 양쪽으..
Software Architecture Antifragile 환경 1. Auto scaling(오토 스케일링) : 자동 확장성 시스템을 구정하고 있는 인스턴스를 하나의 오토 스케일링 그룹이라고 한다. 그리고 묶은 다음 그룹에서 유지되어야 하는 최소의 인스턴스를 지저할 수 있고 사용량에 따라 자동으로 인스턴스를 증가할 수 있는 환경 예시) 5월이나 12월 같이 특수한 이벤트가 있는 달에는 서버의 운영 개수를 늘리고 비수기와 같을 때는 서버의 운영 개수를 다시 줄이는 작업 2. Microservices(마이크로서비스) 마이크로 서비스라는 것은 클라우드 네이티브 아키텍처, 클라우드 네이티브 어플리케이션의 핵심 기존 시스템들이 하나의 거대한 형태로 구축되어서 서비스되었다고 하면 마이크로 서비스라는 것은 전체 서..
롬복과 최신 트랜드 : @RequiredArgsConstructor 막상 개발을 해보면, 대부분이 다 불변이고, 그래서 다음과 같이 필드에 final 키워드를 사용하게 된다. 그런데 생성자도 만들어야 하고, 주입 받은 값을 대입하는 코드도 만들어야 하고… 필드 주입처럼 좀 편리하게 사용하는 방법은 없을까? 역시 개발자는 귀찮은 것은 못 참는다! 다음 기본 코드를 최적화해보자. 기본 코드 @Component public class OrderServiceImpl implements OrderService { private final MemberRepository memberRepository; private final DiscountPolicy discountPolicy; @Autowired // ⭐ 생성자..
과거에는 수정자 주입과 필드 주입을 많이 사용했지만, 최근에는 스프링을 포함한 DI 프레임워크 대부분이 생성자 주입을 권장한다. 그 이유는 다음과 같다. 생성자 주입을 권장하는 이유? "불변" 대부분의 의존관계 주입은 한번 일어나면 애플리케이션 종료시점까지 의존관계를 변경할 일이 없다. 오히려 대부 분의 의존관계는 애플리케이션 종료 전까지 변하면 안된다.(불변해야 한다.) 수정자 주입을 사용하면, setXxx 메서드를 public으로 열어두어야 한다. 누군가 실수로 변경할 수 도 있고, 변경하면 안되는 메서드를 열어두는 것은 좋은 설계 방법이 아니다. 생성자 주입은 객체를 생성할 때 딱 1번만 호출되므로 이후에 호출되는 일이 없다. 따라서 불변하게 설계할 수 있다. "누락" 생성자 주입 데이터를 누락 했..
주입할 스프링 빈이 없어도 동작해야 할 때가 있다. 그런데 @Autowired 만 사용하면 required 옵션의 기본값이 true로 되어 있어서 자동 주입 대상이 없으면 오류 가 발생한다. 옵션 처리 자동 주입 대상을 옵션으로 처리하는 방법은 다음과 같다. @Autowired(required=false) : 자동 주입할 대상이 없으면 수정자 메서드 자체가 호출 안된다. org.springframework.lang.@Nullable : 자동 주입할 대상이 없으면 null이 입력된다. Optional : 자동 주입할 대상이 없으면 Optional.empty 가 입력된다. 예제 1. @Autowired(required=false) required는 디폴트가 true이다. 자동 주입할 대상이 없으면 (Spri..