인프런 커뮤니티 질문&답변
네트워크 프로그램 자원종료 Socket 정리 시 closed 사용 문의
작성
·
9
0
[질문 템플릿]
1. 강의 내용과 관련된 질문인가요? (예)
2. 인프런의 질문 게시판과 자주 하는 질문에 없는 내용인가요? (예)
3. 질문 잘하기 메뉴얼을 읽어보셨나요? (예)
[질문 내용]
네트워크 프로그램 자원종료 관련 이해가 안되는 부분이 있어서 문의드립니다.
[SessionManagerV6]
public synchronized void closeAll() {
for (SessionV6 session : sessions) {
session.close();
}
sessions.clear();
}
[SessionV6]
// 세션 종료시, 서버 종료시 동시에 호출될 수 있다.
public synchronized void close() {
System.out.println("closed : " + closed);
System.out.println(Thread.currentThread().getName());
if (closed) {
return;
}
closeAll(socket, input, output); // shutdown
closed = true;
log("연결 종료: " + socket);
}서버에서 ShutdownHook이 발생했을 때 2개의 Client에 Socket이 연결되어 있었다고하면
첫번째 Clinet의 Socket이 정리되고 난 후 2번째 Clinet의 Socket이 정리되는 시점에서는
closed 변수가 true이기 때문에 정리가 안되고 return되는거 아닌가요?
제가 잘 못 이해하고 있는걸까요? 추가적으로 로그를 찍어서 상태값을 확인해 봤는데
이해가 잘 되지 않아서 문의드립니다. 아래는 로그 정보입니다.
17:34:32.806 [ shutdown] shutdownHook 실행
closed : false
shutdown
17:34:32.806 [ shutdown] 연결 종료: Socket[addr=/127.0.0.1,port=58474,localport=12345]
closed : false
shutdown
17:34:32.806 [ shutdown] 연결 종료: Socket[addr=/127.0.0.1,port=58480,localport=12345]
17:34:32.807 [ Thread-2] java.net.SocketException: Socket closed
closed : true
Thread-2
17:34:32.807 [ Thread-3] java.net.SocketException: Socket closed
closed : true
Thread-3
17:34:32.807 [ main] 서버 소켓 종료: java.net.SocketException: Socket closed
종료 코드 130 (interrupted by signal 2:SIGINT)(으)로 완료된 프로세스
답변 1
0
안녕하세요, 인프런 AI 인턴입니다. yeon님.
질문해 주신 자바 네트워크 프로그래밍에서의 close() 메서드 동작과 closed 플래그 사용에 관해 설명드리겠습니다.
close() 메서드 안의 closed 플래그는 각 인스턴스의 상태를 나타내기 때문에, 각 SessionV6 객체마다 별도로 관리됩니다. 로그에서 보신 것처럼 close()가 호출될 때 closed 변수가 true임을 확인하실 수 있습니다.
각 인스턴스마다 상태 관리:
closed변수는 각SessionV6객체의 인스턴스 변수입니다. 따라서, 여러 클라이언트(세션)가 있을 경우 각각의SessionV6객체 인스턴스에 따라close()가 독립적으로 실행됩니다.정리 과정:
closeAll()은 모든 세션을 순차적으로 정리하기 위해for루프를 사용합니다. 각 세션의close()메서드가 호출되며, 이 메서드 안에서closed변수의 상태가 확인됩니다. 현재 세션이 이미 종료되었는지(즉,closed가true인지) 확인한 후에, 그렇지 않은 경우 자원을 해제합니다.Shutdown Hook:
Shutdown Hook은 JVM이 종료되기 직전에 호출되는 특별한 스레드로, 여기서 모든 세션에 대해close()가 호출되기 때문에, 그 시점에서 각 세션의closed변수가 각각false상태에서 시작하여, 자원 해제 후true로 설정됩니다.
이해를 돕기 위해 추가적인 질문이나 코드 이해에 도움이 될 수 있는 질문을 주시면 더 많은 도움을 드릴 수 있습니다.
관련 자료와 유사한 질문 및 답변은 다음을 참고하시기 바랍니다:
저는 질문자님의 이해를 돕고자 지식공유자님의 기존 답변을 참고하여 유사한 답변 링크를 추천해드리고 있습니다. 현재 베타 기능으로 답변이 만족스럽지 않을 수 있는 점 양해 부탁드립니다. 🙏 추가적으로 궁금한 점이 있으시면, 이어서 질문해 주세요. 곧 지식공유자께서 답변해 주실 것입니다.





