강의

멘토링

커뮤니티

인프런 커뮤니티 질문&답변

yeon님의 프로필 이미지
yeon

작성한 질문수

김영한의 실전 자바 - 고급 2편, I/O, 네트워크, 리플렉션

네트워크 프로그램6 - 자원 정리4

네트워크 프로그램 자원종료 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임을 확인하실 수 있습니다.

  1. 각 인스턴스마다 상태 관리: closed 변수는 각 SessionV6 객체의 인스턴스 변수입니다. 따라서, 여러 클라이언트(세션)가 있을 경우 각각의 SessionV6 객체 인스턴스에 따라 close()가 독립적으로 실행됩니다.

  2. 정리 과정: closeAll()은 모든 세션을 순차적으로 정리하기 위해 for 루프를 사용합니다. 각 세션의 close() 메서드가 호출되며, 이 메서드 안에서 closed 변수의 상태가 확인됩니다. 현재 세션이 이미 종료되었는지(즉, closedtrue인지) 확인한 후에, 그렇지 않은 경우 자원을 해제합니다.

  3. Shutdown Hook: Shutdown Hook은 JVM이 종료되기 직전에 호출되는 특별한 스레드로, 여기서 모든 세션에 대해 close()가 호출되기 때문에, 그 시점에서 각 세션의 closed 변수가 각각 false 상태에서 시작하여, 자원 해제 후 true로 설정됩니다.

이해를 돕기 위해 추가적인 질문이나 코드 이해에 도움이 될 수 있는 질문을 주시면 더 많은 도움을 드릴 수 있습니다.

관련 자료와 유사한 질문 및 답변은 다음을 참고하시기 바랍니다:

저는 질문자님의 이해를 돕고자 지식공유자님의 기존 답변을 참고하여 유사한 답변 링크를 추천해드리고 있습니다. 현재 베타 기능으로 답변이 만족스럽지 않을 수 있는 점 양해 부탁드립니다. 🙏 추가적으로 궁금한 점이 있으시면, 이어서 질문해 주세요. 곧 지식공유자께서 답변해 주실 것입니다.

yeon님의 프로필 이미지
yeon

작성한 질문수

질문하기