해결된 질문
작성
·
100
0
@Bean에 초기화 소멸 메서드 등록할 때 질문입니다!
public class NetworkClient {
private String url;
public NetworkClient() {
System.out.println("생성자 호출, url = " + url);
}
public void setUrl(String url) {
this.url = url;
}
//서비스 시작시 호출
public void connect() {
System.out.println("connect: " + url);
}
public void call(String message) {
System.out.println("call: " + url + " message = " + message);
}
//서비스 종료시 호출
public void disConnect() {
System.out.println("close + " + url);
}
public void init() {
System.out.println("NetworkClient.init");
connect();
call("초기화 연결 메시지");
}
public void close() {
System.out.println("NetworkClient.close");
disConnect();
}
@Configuration
static class LifeCycleConfig {
@Bean(initMethod = "init", destroyMethod = "close")
public NetworkClient networkClient() {
NetworkClient networkClient = new NetworkClient();
networkClient.setUrl("http://hello-spring.dev");
return networkClient;
}
}
결과
생성자 호출, url = null
NetworkClient.init
connect: http://hello-spring.dev
call: http://hello-spring.dev message = 초기화 연결 메시지
13:33:10.029 [main] DEBUG
org.springframework.context.annotation.AnnotationConfigApplicationContext -
Closing NetworkClient.close
close + http://hello-spring.dev
스프링 빈에 하기위해 networkClient객체가 생성되고 의존관계 주입까지 끝난 다음에
networkClient.setUrl("http://hello-spring.dev"); 로 url을 초기화하기 전에
init() 메서드가 실행되는 걸로 이해를 했는데, 그럼 init() 메서드가 connect 호출 할 때 url은 여전히 null일테니 url의 초기화가 먼저 일어나야 합니다.
그런데 초기화 콜백은 스프링 빈이 객체를 생성하고 의존관계 주입이 완료된 후,
초기화가 되기 전에 일어나는 거 아닌가요..
이럼 앞뒤가 안 맞는데 제가 놓치고있는 부분을 알려주시면 감사하겠습니다.
답변 1
2
안녕하세요. 권정익님, 공식 서포터즈 David입니다.
빈 생성 -> 의존관계 주입 -> 초기화 콜백 순으로 진행됩니다.
LifeCycleConfig에서 NetworkClient 빈 생성 과정은 NetworkClient 생성 -> setUrl 호출 -> 생성된 NetworkClient 반환 순으로 진행됩니다. 반환된 객체는 스프링 프레임워크에 의해 싱글톤 빈 목록에 추가됩니다. 추가되기 전까지는 스프링에서 관리하는 객체(빈)가 아니라 일반적인 객체(빈 아님)입니다.
즉, LifeCycleConfig에서 NetworkClient 객체가 생성되고 스프링 프레임워크를 통해 싱글톤 빈 컨테이너에 빈으로 등록되는 과정까지를 빈 생성 과정으로 볼 수 있습니다.
이 2가지를 조합하면 다음과 같습니다
빈 생성 (NetworkClient 생성 -> setUrl 호출 -> 생성된 NetworkClient 반환) -> 의존관계 주입 -> 초기화 콜백 (init 호출)
위 내용을 숙지하신 뒤 다시 코드와 로그를 확인해 주세요:)
감사합니다.
와...깔끔하게 이해됐습니다 감사합니다!