↩뒤로가기

package hello.core.lifecycle;

import org.springframework.beans.factory.DisposableBean;
import org.springframework.beans.factory.InitializingBean;

public class NetworkClient implements InitializingBean, DisposableBean {

    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);

    }

    //의존관계 주입이 모두 끝난 후에 호출됨
    @Override
    public void afterPropertiesSet() throws Exception {
        System.out.println("NetworkClient.afterPropertiesSet");
        connect();
        call("초기화 연결 메시지");

    }

    //종료될 때 호출됨
    @Override
    public void destroy() throws Exception {
        System.out.println("NetworkClient.destroy");
        disconnect();
    }
}

출력 결과

생성자 호출, url = null
NetworkClient.afterPropertiesSet
connect: <http://test.test>
call: <http://test.test> message: 초기화 연결 메시지
13:06:41.690 [main] DEBUG org.springframework.context.annotation.AnnotationConfigApplicationContext - Closing org.springframework.context.annotation.AnnotationConfigApplicationContext@43dac38f, started on Sat Mar 25 13:06:41 GMT+09:00 2023
NetworkClient.destroy
close: <http://test.test>

출력 결과를 보면 초기화 메소드가 주입 완료 후에 적절하게 호출된 것을 확인할 수 있다.

또한 스프링 컨테이너의 종료가 호출되자 소멸 메소드가 호출된 것도 확인할 수 있다.

초기화, 소멸 메소드의 단점

참고: 인터페이스를 사용하는 초기화, 종료 방법은 스프링 초창기에 나온 방법들이며, 지금은 더 나은 방법들이 있기 때문에 거의 사용하지 않는다. 이런 것이 있다는 것만 대충 알고 가자.