inflearn logo
강의

講義

知識共有

キム・ヨンハン氏の実践Java - 上級2編、I/O、ネットワーク、リフレクション

ネットワークプログラム6 - リソース整理4

네트워크 프로그램 자원종료 Socket 정리 시 closed 사용 문의

102

yeon

投稿した質問数 5

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)(으)로 완료된 프로세스

 

java 네트워크 객체지향

回答 2

0

W-Hand

Session 은 결국 서버에 연결된 클라이언트 숫자만큼 생기는 거고 Session 별로 closed 변수는 따로 관리되는 거니까 1번쨰 session을 close 해서 닫는다고 다른 클라이언트와 연결된 2번째 Session 이 영향을 받을 일은 없지 않을까요?

0

communityai8509

안녕하세요, 인프런 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로 설정됩니다.

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

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

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

RequestHandler 버전 간 process() 파라미터 차이 질문

0

74

2

리플렉션 default

0

54

1

그럼 SOURCE나 CLASS는 어떤 경우에 사용하나요?

0

80

2

FileInputStream의 transferTo 사용 시 Buffer 문의

0

66

1

오타 제보 드립니다

0

76

2

강좌 복습 팁이 있으신 분들 공유해주시면 감사하겠습니다.

0

108

1

16강 질문있습니다.

0

51

1

한글이 깨질 떄 어떻게 해야 하나요?

0

80

1

자원 정리시 에러가 발생 했을 때 메모리 상황 및 실무에서 로그 확인 방법

0

94

1

인텔리제이에서 네모(스탑버튼) 누르는 것의 의미

-1

70

1

강의 섹션 8: 네드워크 -프로그램 3부분 10:45 오타?

0

90

2

제대로 이해한게 맞나 궁금합니다

0

80

1

File,Files 강의 2번쨰 Files 07:30 에 tmep 파일들을 다 지운건가요 ?

0

65

1

/.well-known/appspecific/com.chrome.devtools.json 에러에 대해서

0

629

1

Socket 자원을 정리할때 stream 을 정리하지 않는 이유가 궁금합니다.

0

92

1

클라이언트 강제종료시 오류 메세지

0

109

2

고급 2편에는 퀴즈가 없네요?

0

100

1

55. 네트워크 프로그램5 - 자원정리2 질문

0

69

1

클라이언트가 FIN과 함께 보내는 ACK는 무엇에 대한건가요?

1

109

2

BufferedInputStream이 1바이트씩 조회해도 성능이 좋은 이유

0

81

1

오타제보

0

64

2

문자 집합 호환성 여부를 판단할 때

0

54

1

utf-8, char

0

54

1

RequestBody를 읽어올 때

0

72

2