728x90
반응형
NetworkClient.java
package hello.core.lifecycle;
import javax.annotation.PostConstruct;
import javax.annotation.PreDestroy;
// javax -> java 에서 지원하는 패키지
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);
}
// 의존관계 주입이 끝나면 세팅해주는 것
@PostConstruct
public void init() throws Exception {
System.out.println("NetworkClient.init");
connect();
call("초기화 연결 메시지");
}
@PreDestroy
public void close() throws Exception {
System.out.println("NetworkClient.close");
disConnect();
}
}
BeanLifeCycleTest.java
package hello.core.lifecycle;
import org.junit.jupiter.api.Test;
import org.springframework.context.ApplicationContext;
import org.springframework.context.ConfigurableApplicationContext;
import org.springframework.context.annotation.AnnotationConfigApplicationContext;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;
public class BeanLifeCycleTest {
@Test
public void lifeCycleTest() {
ConfigurableApplicationContext ac = new AnnotationConfigApplicationContext(LifeCycleConfig.class);
// AnnotationConfigApplicationContext ac = new AnnotationConfigApplicationContext(LifeCycleConfig.class);
// ApplicationContext ac = new AnnotationConfigApplicationContext(LifeCycleConfig.class);
NetworkClient client = ac.getBean(NetworkClient.class);
ac.close(); // 원래는 안해줬는데, 생명주기를 끝내려면 AnnotationConfigApplicationContext를 쓰거나
// ConfigurableApplicationContext로 객체 타입을 지정해주면 된다.
}
@Configuration
static class LifeCycleConfig {
// @Bean(initMethod = "init", destroyMethod = "close")
@Bean
public NetworkClient networkClient() {
NetworkClient networkClient = new NetworkClient();
networkClient.setUrl("http://hello-spring.dev");
return networkClient;
}
}
}
"실행 결과"
'@PostConstruct', '@PreDestroy' 이 두 애노테이션을 사용하면 가장 편리하게 초기화와 종료를 실행할 수 있다.
"@PostConstruct, @PreDestroy 애노테이션 특징"
- 최신 스프링에서 가장 권장하는 방법이다.
- 애노테이션 하나만 붙이면 되므로 매우 편리하다
- 패키지를 잘 보면 'javax.annotation.PostConstruct' 이다. 스프링에 종속적인 기술이 아니라 JSR-250라는 자바 표준이다. 따라서 스프링이 아닌 다른 컨테이너에서도 동작한다.
- 컴포넌트 스캔과 잘 어울린다.
- 유일한 단점은 외부 라이브러리에는 적용하지 못한다는 것이다. 외부 라이브러리를 초기화, 종료해야 하면 @Bean의 기능을 사용하자.
"정리"
- @PostConstruct, @PreDestroy 애노테이션을 사용하자
- 코드를 고칠 수 없는 외부 라이브러리를 초기화, 종료해야 하면 '@Bean'의 'initMethod', 'destroyMethod'를 사용하자
728x90
반응형
'스프링 > 핵심 원리' 카테고리의 다른 글
[Spring] 프로토타입 스코프 (0) | 2022.03.06 |
---|---|
[Spring] 빈 스코프란? (0) | 2022.03.06 |
[Spring] 빈 등록 초기화, 소멸 메서드 (0) | 2022.03.04 |
[Spring] 인터페이스 InitializingBean, DisposableBean (0) | 2022.03.04 |
[Spring] 빈 생명주기 콜백 시작 (0) | 2022.03.04 |
댓글