728x90
반응형
설정 정보에 '@Bean(initMethod = "init", destroyMethod = "close")' 처럼 초기화, 소멸 메서드를 지정할 수 있다.
"설정 정보를 사용하도록 변경"
NetworkClient.java
package hello.core.lifecycle;
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() throws Exception {
System.out.println("NetworkClient.init");
connect();
call("초기화 연결 메시지");
}
public void close() throws Exception {
System.out.println("NetworkClient.close");
disConnect();
}
}
https://drcode-devblog.tistory.com/361 에서 implements했던 인터페이스들을 지우고, 함수로 정의한다.
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")
public NetworkClient networkClient() {
NetworkClient networkClient = new NetworkClient();
networkClient.setUrl("http://hello-spring.dev");
return networkClient;
}
}
}
@Configuration
static class LifeCycleConfig {
@Bean(initMethod = "init", destroyMethod = "close")
public NetworkClient networkClient() {
NetworkClient networkClient = new NetworkClient();
networkClient.setUrl("http://hello-spring.dev");
return networkClient;
}
}
@Bean 애노테이션 옆에 initMethod와 destroyMethod를 지정해준다.
"결과"
"설정 정보 사용 특징"
- 메서드 이름을 자유롭게 줄 수 있다.
- 스프링 빈이 스프링 코드에 의존하지 않는다.
- 코드가 아니라 설정 정보를 사용하기 때문에 코드를 고칠 수 없는 외부 라이브러리에도 초기화, 종료 메서드를 적용할 수 있다.
"종료 메서드 추론"
- '@Bean의 destroyMethod' 속성에는 아주 특별한 기능이 있다.
- 라이브러리는 대부분 'close', 'shutdown' 이라는 이름의 종료 메서드를 사용한다.
- @Bean의 'destroyMethod'는 기본값이 '(inferred)' (추론)으로 등록되어 있다.
- 이 추론 기능은 'close', 'shutdown' 라는 이름의 메서드를 자동으로 호출해준다. 이름 그대로 종료 메서드를 추론해서 호출해준다.
- 따라서 직접 스프링 빈으로 등록하면 종료 메서드는 따로 적어주지 않아도 잘 작동한다.
- 추론 기능을 사용하기 싫으면 'destroyMethod=""'처럼 빈 공백을 지정하면 된다.
728x90
반응형
'스프링 > 핵심 원리' 카테고리의 다른 글
[Spring] 빈 스코프란? (0) | 2022.03.06 |
---|---|
[Spring] 애노테이션 @PostConstruct, @PreDestroy (0) | 2022.03.04 |
[Spring] 인터페이스 InitializingBean, DisposableBean (0) | 2022.03.04 |
[Spring] 빈 생명주기 콜백 시작 (0) | 2022.03.04 |
[Spring] 자동, 수동의 올바른 실무 운영 기준 (0) | 2022.03.03 |
댓글