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("connetc: " + url); //임시로 출력만.
}
public void call(String message){
System.out.println("call : " + url + "message = " + message);
}
//서비스 종료 시 안전하게 연결끊기
public void disconnect(){
System.out.println("close : " + url);
}
@PreDestroy
public void close() {
disconnect();
}
@PostConstruct
public void init() {
connect();
call("초기화 연결 메시지");
}
}
public class BeanLifeCycleTest {
@Test
public void lifeCycleTest(){
ConfigurableApplicationContext ac =
new AnnotationConfigApplicationContext(LifeCycleConfig.class); //ApplicationContext는 close를 제공 안한다. Configurable이라는 하위까지 내려가야 함.
NetworkClient client = ac.getBean(NetworkClient.class);
ac.close();
}
@Configuration
static class LifeCycleConfig{
@Bean
public NetworkClient networkClient(){
NetworkClient networkClient = new NetworkClient();
networkClient.setUrl("http://hello-spring.dev");
return networkClient;
}
}
}
간단. 그냥 @PostConstruct, @PreDestroy만 붙여주면 됨.
참고로 저건 javax꺼라, 스프링 말고 다른 컨테이너에도 사용이 가능함.
근데 단점은, 외부 라이브러리에 적용 불가.
왜냐하면 보통 외부 라이브러리는 java 파일이 아닌 컴파일 된 class 파일, 그걸 jar로 패키징하여 배포.
그래서 class 내부 코드를 수정하기 불가능 한건 아니지만 까다로움, 즉 외부 라이브러리 코드를 수정하기 까다롭기 때문에 외부 라이브러리에서 사용하기 까다로움.
외부 라이브러리에서 콜백을 사용하고 싶다면, 전에 썼던 @Bean(initMethod = "~") 이거 쓰면 됨.
그런 경우 말고는 보통 이걸로 씀.
'스프링 > 1. 스프링 핵심 원리' 카테고리의 다른 글
46강. 프로토타입 빈. (0) | 2023.07.24 |
---|---|
45강. 빈 스코프 (0) | 2023.07.23 |
43강. 빈 등록시 설정 정보에 초기화, 소멸 메서드 지정 (0) | 2023.07.23 |
42강. 빈 사용 전, 빈 소멸 전 콜백 (0) | 2023.07.23 |
41강. 빈 생명주기 (0) | 2023.07.23 |