티스토리 뷰
반응형
TCP는 3-way handshake 과정을 통해 연결을 설정하고 4-way handshake를 통해 해제한다.
3-way Handshake란?
TCP 3-way Handshake는 TCP/IP 프로토콜을 이용해서 통신을 하는 응용프로그램이 데이터를 전송하기 전에 먼저 정확한 전송을 보장하기 위해 상대방 컴퓨터와 사전에 세션을 수립하는 과정을 의미한다.
3-way Handshake의 역할은, 양쪽 모두 데이터를 전송할 준비가 되었다는 것을 보장하는 것이다.
3-way Handshake의 과정을 살펴보자.
- 클라이언트는 서버에 접속을 요청하는 SYN 패킷을 보낸다. 이 때 클라이언트는 SYN을 보내고 SYN/ACK 응답을 기다리는 SYN_SENT 상태가 된다.
- 서버는 SYN 요청을 받고 클라이언트에게 요청을 수락한다는 ACK와 SYN Flag가 설정된 패킷을 발송하고 클라이언트가 다시 ACK로 응답하기를 기다린다. 이 때 서버는 SYN_RECEIVED 상태가 된다.
- 클라이언트는 서버에게 ACK를 보낸 후부터는 연결이 이루어지고 데이터가 오가게 되는 것이다. 이 때 서버 상태는 ESTABLISHED가 된다.
4-way Handshake란?
4-way Handshake 과정을 살펴보자.
- 클라이언트가 연결을 종료하겠다는 FIN Flag를 전송한다.
- 서버에서는 FIN 패킷을 정상적으로 받았다는 ACK를 클라이언트에 전송해준다. 그 후 서버는 CLOSE-WAIT 상태로 빠져든다.
- 연결을 종료한 후 서버는 클라이언트에게 FIN Flag를 전송해준다.
- 서버로부터 전송된 FIN Flag를 받은 클라이언트는 확인을 알리는 ACK를 서버로 전송한 후, 일정 시간동안 TIME-WAIT 상태에 빠지게 된다.
- 클라이언트로 부터 ACK를 받은 서버는 소켓을 Close하고 두 TCP간의 세션이 종료된다.
- TIME-WAIT에 빠진 클라이언트는 서버로 부터 FIN을 수신하더라도, 일정시간동안 세션을 유지하며 도착하지 않은 패킷을 기다린다.
연결 종료를 3-way Handshake 대신 4-way Handshake로 왜 해야하나?
클라이언트가 데이터 전송을 마쳤다고 하더라도 서버는 아직 보낼 데이터가 남아있을 수 있기 때문에 일단 FIN에 대한 ACK만 먼저 보내고, 데이터를 모두 전송한 후에 자신도 FIN 메시지를 보내기 때문이다.
TIME-WAIT는 왜?
여기서 클라이언트가 서버로부터 FIN을 수신하더라도 일정시간 세션을 유지하는 이유는, 서버에서 FIN을 전송하기 전에 클라이언트가 전송한 패킷이 라우팅 지연이나 패킷 유실로 인한 재전송 등으로 인해 해당 ACK 패킷이 FIN 패킷보다 늦게 도착하는 상황을 대비해야하기 때문이다.
- 클라이언트에서 세션을 종료시킨 후 뒤늦게 도착하는 패킷이 있다면 이 패킷은 드롭되고 데이터는 유실될 것이다. 이러한 현상에 대비하여 클라이언트는 서버로부터 FIN을 수신하더라도 일정시간(default 240) 동안 세션을 남겨놓고 잉여 패킷을 기다리는 과정을 거치게 되는데, 이 과정을 TIME_WAIT이다.
반응형
'Network' 카테고리의 다른 글
[Network] DNS 과정 (0) | 2020.06.08 |
---|---|
[Network] TCP와 UDP (0) | 2020.05.11 |
[Network] SSL 인증서 (0) | 2020.05.10 |
[Network] HTTP 1.1 vs HTTP 2.0 (0) | 2020.05.03 |
[Network] SSL(대칭키와 공개키) (0) | 2020.04.28 |
댓글
공지사항
최근에 올라온 글
최근에 달린 댓글
- Total
- Today
- Yesterday
링크
TAG
- ifPresent
- junit
- springboot
- 인프런
- 팩토리 메소드 패턴
- 점층적 생성 패턴
- try with resources
- java
- JPA
- try catch finally
- 이펙티브자바
- flatMap
- 연관관계
- package-private
- 복사 팩토리
- Spring
- 정적팩터리메서드
- Effective Java
- 생성자
- 자바8
- mustache
- 빌더 패턴
- jdk버전
- 김영한
- 스프링부트
- effectivejava
- java8
- 이펙티브 자바
- @Lazy
- 빈 순환 참조
일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
1 | 2 | 3 | 4 | |||
5 | 6 | 7 | 8 | 9 | 10 | 11 |
12 | 13 | 14 | 15 | 16 | 17 | 18 |
19 | 20 | 21 | 22 | 23 | 24 | 25 |
26 | 27 | 28 | 29 | 30 | 31 |
글 보관함