빈 스코프빈 스코프 : 빈이 존재할 수 있는 범위를 의미한다.@Scope("스코프 종류")로 빈 스코프를 지정할 수 있다. 스프링 빈은 기본적으로 싱글톤 스코프로 생성되기 때문에 스프링 컨테이너의 시작과 함께 생성되었다가 컨테이너 종료될 때 소멸한다. 스프링 빈에서 지원하는 스코프 종류싱글톤 : 기본 스코프로 스프링 컨테이너의 시작과 종료까지 유지되는 가장 넓은 범위의 스코프이다.프로토타입 : 스프링 컨테이너는 프로토타입 빈의 생성과 의존관계 주입, 초기화까지만 관여하고 더이상 관리하지 않는 매우 짧은 범위의 스코프이다.스프링 빈에서 지원하는 웹 관련 스코프 종류request : 웹 요청이 들어오고 나갈 때까지 유지되는 스코프이다.session : 웹 세션이 생성되고 종료될 때까지 유지되는 스코프이다...
빈 생명주기 콜백요청에 대한 빠른 응답을 위해서 데이터베이스 커넥션 풀, 네트워크 소켓처럼 애플리케이션 시작 시점에 필요한 연결을 미리 해두고 애플리케이션 종료 시점에 연결을 모두 종료하는 작업이 필요하다.스프링에서 이러한 기능을 지원해주기 위해서 다양한 생명주기 콜백을 제공한다. 빈 생명주기 콜백 : 스프링 빈이 생성되거나 종료되기 전에 스프링이 빈의 메소드를 호출해줄 수 있는 기능이다. 스프링이 지원하는 빈 생명주기 콜백 3가지인터페이스 (InitializingBean, DisposableBean)설정 정보에 초기화 메소드, 종료 메소드 지정@PostConstruct, @PreDestroy 어노테이션 지원 스프링 빈은 라이프 사이클을 가진다.객체 생성 -> 의존관계 주입생성자 주입은 예외로 객체 생..
자동 의존관계 주입자동 의존관계 주입 방법생성자 주입수정자 주입(Setter 주입)필드 주입일반 메소드 주입자동 의존관계 주입(@Autowired)은 스프링 컨테이너에서 관리하는 스프링 빈에서만 수행되는 기능이다. public class MemberService implements Service { private final Repository repository; //생성자 주입 @Autowired public MemberService(Repository repository) { this.repository = repository; }}생성자 주입 : 생성자를 통해서 의존관계를 주입 받는 방법이다.생성자 호출시점에 딱 1번만 호출되는 것이 보장된다.불변, 필수적 의..
컴포넌트 스캔@Configuration@ComponentScan( excludeFilters = @ComponentScan.Filter(type = FilterType.ANNOTATION, classes = Configuration.class))public class AutoAppConfig {}스프링 설정 파일에 @ComponentScan 선언 시 @Component로 선언된 클래스를 찾아서 자동으로 스프링 빈으로 등록한다.스프링 설정 파일에 @Bean으로 따로 등록하지 않아도 스프링 빈으로 등록해준다.excludeFilters 옵션으로 컴포넌트 스캔 제외 대상을 지정할 수 있다.excludeFilters 옵션으로 컴포넌트 스캔 대상을 지정할 수 있다.컴포넌트 스캔 : @Compone..
싱글톤 Config config = new Config();MemberService memberService1 = config.memberService();MemberService memberService2 = config.memberService();스프링 없는 순수한 DI 컨테이너 Config 클래스의 경우 호출할 때마다 새로운 객체를 생성해야한다.메모리 낭비가 심하다는 단점이 있다.해결 방안으로 객체는 딱 1개만 생성되고 이후 공유하도록 설계하는 것. 싱글톤 패턴 (Singleton Pattern) : 클래스의 인스턴스(객체)가 딱 1개만 생성되는 것을 보장하는 디자인 패턴이다.객체를 2개 이상 생성하지 못하도록 막아야 한다.생성자를 private으로 선언해서 외부에서 사용하지 못하도록 막아야한다..
스프링 컨테이너// 스프링 컨테이너 생성ApplicationContext applicationContext = new AnnotationConfigApplication(JavaConfig 클래스.class);ApplicationContext = 스프링 컨테이너ApplicationContext는 인터페이스로 다형성이 적용되어 있다.스프링 컨테이너는 XML 기반이나 애노테이션 기반의 자바 설정 클래스로 만들 수 있다.애노테이션 기반 자바 설정 클래스 = @Configuration으로 선언된 클래스스프링 컨테이너를 부를 때 BeanFactory, ApplicationContext를 구분해서 이야기한다.BeanFactory는 보통 직접 사용하지 않기에 일반적으로 ApplicationContext를 스프링 컨테이..
객체 지향 원리 적용테스트 케이스 작성 시JUnit을 이용한 테스트 케이스 작성 시 @DisplayName("....")으로 선언하면 테스트 결과에서 보여줄 이름을 지정할 수 있으며 한글로 작성할 수 있다.테스트 케이스는 성공 케이스도 중요하지만 실패 케이스도 중요하기에 둘 다 테스트 해봐야한다.관심사 분리각자에게 주어진 역할에만 집중해야하기에 역할과 책임을 분리해주는 것이 중요하다!!ex) 배우는 배우의 역할을, Service는 Service의 역할을, Repository는 Repository의 역할에만 집중해야 한다.코드 내부에서 어떤 구현체가 사용될지 정하는 것은 이들의 역할이 아니다.ex) 배우가 상대 배우를 지정하지 않는 것처럼 Service 클래스 내부에서 사용되는 Repository의 구현체..
예제 만들기설계 시 인터페이스를 설계를 먼저하고 구현체를 생성하는 방식으로 설계하면 좋다.ex) Service 인터페이스, Repository 인터페이스Service 구현체가 Repository 인터페이스에 의존하는 방식으로 설계 (OCP, DIP 원칙 준수) Entity 설계 시 id의 값을 Long 타입으로 지정하는 이유는?long은 기본형으로 초기화하지 않을 경우 0으로 값이 세팅된다.0이 실제 값인지 id가 없어서 0으로 세팅이 된 것인지 구분할 수 없게 된다.Long은 참조 타입으로 값을 초기화 하지 않으면 null로 세팅이 되서 long과 달리 기본 세팅값과 구분할 수 있다. Enum 타입의 값을 비교 시 equals()가 아닌 ==으로 비교한다.출처 : [인프런 김영한 스프링 핵심 원리 - ..
스프링 스프링 : 여러가지 기술들의 모음으로 스프링 프레임워크와 스프링 부트가 기반이며 스프링 데이터, 세션, 시큐리티, Rest Docs, 배치, 클라우드 등이 있다.스프링의 핵심은 스프링 프레임워크스프링을 편리하게 사용할 수 있도록 해주는 것이 스프링 부트 스프링 프레임워크스프링 DI 컨테이너, AOP, 트랜잭션, MVC, WebFlux 등의 기술들을 지원한다.스프링 부트스프링 프레임워크를 사용해서 편리하게 도와주는 기술로 스프링 부트만을 사용할 수는 없다. 스프링 부트의 장점Tomcat같은 웹 서버를 내장해서 별도의 웹 서버를 설치하지 않아도 되므로 단독으로 실행할 수 있는 스프링 애플리케이션을 쉽게 생성할 수 있다.손쉬운 빌드 구성을 위한 starter 종속성 제공스프링과 3rd party(외부)..