빈 생명주기 콜백

이원석·2022년 2월 3일

Spring

목록 보기
10/20
post-thumbnail
*인프런 김영한 강사님의 강좌를 참고하여 정리한 내용입니다.*

빈 생명주기 콜백


DB 커넥션 풀이나, 네트워크 소켓처럼 애플리케이션 시작 시점에 필요한 연결을 미리 해두고 애플리케이션 종료 시점에 연결을 모두 종료하는 작업을 진행하려면 객체의 초기화와 종료 작업이 필요하다.

그렇다면 빈이 생성되고 종료되는 빈의 생명주기에 대해서 알아야한다!





스프링 빈의 라이프 사이클


스프링 빈은 객체를 생성하고, 의존관계 주입이 다 끝나야 필요한 데이터를 사용할 수 있는 준비가 완료된다.
따라서 초기화 작업은 의존관계 주입이 모두 완료가 된 후에 호출해야 한다.

스프링 컨테이너 생성    →    스프링 빈 생성    →    의존관계 주입    →     

초기화 콜백    →    (데이터) 사용    →    소멸전 콜백    →    스프링 종료


그런데.. 개발자가 의존관계 주입이 모두 완료된 시점을 어떻게 알 수 있을까?
바로 스프링이 콜백 메서드를 통해 의존관계 주입이 끝난 뒤의 초기화 시점을 알려주는 다양한 기능을 제공한다.


콜백

  • 초기화 콜백 : 빈이 생성되고, 빈의 의존관계 주입이 완료된 후 호출
  • 소멸전 콜백 : 빈이 소멸되기 직전에 호출

객체의 생성과 초기화를 분리하자

생성자는 필수 파라미터를 받고, 메모리를 할당하여 객체를 생성하는 책임을 가진다.반면에 초기화는 이렇게 생성된 값들을 활용하여 외부 커넥션을 연결하는 등 무거운 동작을 수행한다.
따라서 생성자 안에서 무거운 초기화 작업을 추가하는 것 보다는 객체를 생성하는 부분과 초기화를 하는(Setter) 부분을 명확하게 나누는 것이 유지보수 측면에서 더 좋다!

그렇다면 가장 대표적으로 빈 생명주기 콜백을 지원하는 @PostConstruct와 @PreDestory 애노테이션에 대해 알아보자!





@PostConstruct, @PreDestroy


특징

  • 최신 스프링에서 가장 권장하는 방법이며 애노테이션 하나만 붙이면 된다.
  • javax.annotataion 패키지에 포함되어, 스프링 종속적인 기술이 아닌 자바 표준 기술이다. 따라서 스프링이 아닌 다른 컨테이너에서도 동작한다.
  • 컴포넌트 스캔과 잘 어울린다.


간단한 예시 코드

public class NetworkClient {
	...
    
    // 초기화 콜백
    @PostConstruct
    public void init() {
    	System.out.println("NetworkClient.init");
        connect();
        call("초기화 연결 메시지");
    }
    
    // 소멸전 콜백
    @PreDestroy
    public void close() {
    	System.out.println("NetworkClient.close");
        disConnect();
    }
}

해당 어노테이션을 사용하여 편리하게 초기화와 빈 종료를 실행할 수 있다.



0개의 댓글