본문 바로가기

분류 전체보기

(183)
빈 스코프 Scope 라는 단어는 범위 정도로 해석할 수 있을 것 같다. 변수 스코프란, 그 변수가 유효한 범위를 의미하듯이. 그런 의미로 스프링에서 빈 스코프는 빈이 유효한 범위 즉 라이프사이클의 범위를 의미한다. 스프링 빈은 기본적으로 싱글톤으로 생성되어 스프링 컨테이너가 생성되고 종료될때까지이다. 오늘 공부해볼 스프링의 빈 스코프는 싱글톤 스코프를 포함하여 세가지이다. 싱글톤 : 스프링 컨테이너가 뜨고 종료될때까지 빈이 유지되는 스코프. 가장 넓은 범위이다. 프로토타입 : 빈의 라이프사이클중 빈의 생성, 등록, 주입, 초기화까지만의 스코프를 가진다. 웹 관련 스코프 request : 웹 요청이 들어오고 나갈때까지의 스코프를 가진다. session : 세션이 생성되고 종료될 때까지의 스코프를 가진다. appli..
스프링 빈의 생명주기와 초기화 분리 스프링 빈도 객체이기 때문에 초기화가 필요할 것이다. 그리고 우리는 이 초기화를 보통 생성자에서 처리하게 된다. 필드같은 간단한 초기화는 괜찮지만, 만약 데이터베이스의 커넥션풀을 미리 셋팅하는 것과 같은 무거운 작업들은 ? 소켓 통신을 위해 소켓을 미리 열어두는 초기화 작업들은 ? 객체의 생성과 초기화는 분리해야한다. 객체의 생성과 객체의 초기화는 다른 책임이다. SRP 의 원칙에 따라 이 두 로직은 분리되는 것이 좋다. 물론 간단한 필드 한두개를 초기화하는 데에 생성자를 쓰지 않고 따로 하는 것은 비효율적일 수 있지만, 위의 예인 커넥션풀처럼 무거운 초기화 작업들은 분리하는 것이 좋다. 오늘은 이 초기화라는 작업을 스프링에서 어떻게 분리하여 처리하게 도와주는지 알아본다. 스프링 컨테이너를 사용해 빈을 ..
자동 주입시 빈이 2개 이상일 때 문제 해결 @Autowired 는 타입으로 빈을 조회한다. 또, 스프링의 객체지향적 인 코드를 짜기 위해 우리는 인터페이스와 스프링 컨테이너를 이용하여 DIP, OCP 를 만족시킨다. 그런데, 스프링에서 @Autowired 로 빈을 주입하기 위해 getBean 메서드와 같이 빈을 조회할 때에는 생성자, 수정자 주입시 매개변수의 파라미터, 필드 주입시 필드의 타입을 보고 해당 타입의 하위 타입을 모두 가져오게 된다. 그런데 만약 하위 타입들 중 @Component 로 등록된게 2개 이상이라면? 스프링은 오류를 뱉게 된다. 예를 들어 아래와 같은 서비스의 계층구조가 있다고 생각해보자. 그런데 AutoDrivingService, UserDrivingService 가 모두 빈에 등록된 것이다. 코드로 보면 대략 이럴 것이..
생성자 자동 주입의 장점, @RequiredArgsConstructor 불변이다. 의존관계를 설정하는 부분과 시스템을 돌아가게하는 부분은 분리되어야 한다. (CleanCode) 변경 가능성을 최소화하라. (Effective Java) 수정자 주입을 사용하려면 setter 를 public 으로 열어야한다. 객체의 상태가 변경가능하면 문제가 생길 여지가 너무 많다. 생성자 주입은 빈이 등록되기위해 싱글톤 객체가 생성될 때 딱 한번만 주입하고 변경하지 않는다. 테스트의 편함 수정자 주입에서는 의존관계가 무엇이 있었는지 있긴 한지는 코드의 setter 를 까봐야한다. 또한 런타임에 에러가 나게 된다. 생성자 주입은 생성자의 매개변수로 주지 않으면 애초에 컴파일에러가 난다. 또, IDE 의 도움을 받으면 코드 작성시 매개변수를 볼 수 있다. final 생성자 주입방식을 쓰면 fina..
@Autowired @Autowired 이 에너테이션은 스프링 컨테이너에 등록된 빈들 중에서 타입이 일치하는 빈을 찾아와 자동으로 주입시킨다. 생성자 주입 생성자 호출 시점에 한번만 주입됨이 보장된다. 의존관계를 처음 셋팅할 때 한번만 설정하고 이후에는 변경하고 싶지 않을때. 의존 객체가 불변이 된다. (final 도 붙이자.) final 이 붙은 필드는 초기화가 무조건 필요하다. (하지 않으면 컴파일타임에 에러남) 생성자 주입이니 생성자에서 초기화해주며, 필수값임을 나타낼 수 있다. 생성자가 하나라면, @Autowired 를 생략할 수 있다. 생성자 오버로딩으로 두개 이상이라면 어떤 것을 의존관계 설정에 이용할 것인지 모르기 떄문에 생략하면 안되고 지정해줘야한다. 수정자(Setter) 주입 선택적이다. 주입을 해도 되고 ..
@ComponentScan @ComponentScan 에플리케이션의 컴포넌트들을 찾아 빈으로 등록한다. 컴포넌트란, @Component 에너테이션이 붙은 클래스. @Configuration 할 클래스에 붙여준다. @ComponentScan @Configuration public class AutoConfig { } 이 컴포넌트 스캔이 있기 전에는 @Configuration 으로 지정한 클래스에 @Bean 에너테이션을 이용하여, 빈 등록과 의존성 주입을 했다. 하지만 @ComponentScan 을 이용한 빈 등록을 처리하면, 의존성 주입은 어디서 할까? --> @Autowired 를 이용하여 @Component 에너테이션이 붙은 클래스에서 자동 주입을 한다. 수동 빈 설정과 같이 ApplicationContext 생성시 해당 설정 ..
DTO 는 어떻게 써야하나 Dto 를 서비스단까지 가져간 후, Entity 객체로 바꿈. 이 떄, 바꾸는 로직은 Entity 객체의 생성자에 작성. Controller 와 Service 로직 사이의 DTO 와 Entity 변환은 다음과 같은 경우의 수가 있을 수 있다. 결정하는 기준은 한가지다. DTO 와 Entity 간의 변환은 어디에서 이루어질 것인가 ? 요청 : Controller -> Service Controller에서 DTO를 Entity로 변환시켜 Entity 를 Service에게 파라미터로 넘김. Controller에서 DTO 를 Service에 파라미터로 바로 넘기고, Service가 Entity 로 바꿈. 응답 : Service -> Controller Service가 Controller로 응답을 보낼 때, En..
Java Garbage Collection alkhwa-113.tistory.com/entry/1%EC%A3%BC%EC%B0%A8-JVM%EC%9D%80-%EB%AC%B4%EC%97%87%EC%9D%B4%EB%A9%B0-%EC%9E%90%EB%B0%94-%EC%BD%94%EB%93%9C%EB%8A%94-%EC%96%B4%EB%96%BB%EA%B2%8C-%EC%8B%A4%ED%96%89%ED%95%98%EB%8A%94-%EA%B2%83%EC%9D%B8%EA%B0%80 자바를 쓸 때 JVM 은 OS 에서 메모리를 할당받아 에플리케이션에 필요한 자원을 사용한다. 그 중 우리가 자주 쓰는 참조 타입들은 메모리의 힙 영역에 저장된다고 공부했었는데, 매번 쌓이는 힙 영역을 개발자가 관리하지 않아도 괜찮은 이유가 Java Garbage Collection 때..