-
TCP 3 way handshake & 4 way handshake네트워크/네트워크 정리 2020. 1. 29. 17:53
그전에
SYN Packet과 ACK Packet 이란?
SYN : synchronize sequence number
ACK : acknowledgement
TCP Header엔은 Code Bit라는 부분이 존재하고 총 6Bit로 이루어져 있습니다.
Urg-Ack-Psh-Rst-Syn-Fin 순서로 해당 위치의 비트가 1이면 해당 패킷의 내용을 담고 있다는 것을 나타냅니다.
(예 : SYN 패킷일 경우 000010 )
* TCP 3-way Handshake 란?
TCP는 장치들 사이에 논리적인 접속을 성립(establish)하기 위하여 three-way handshake를 사용한다.
TCP 3 Way Handshake는 TCP/IP프로토콜을 이용해서 통신을 하는 응용프로그램이 데이터를 전송하기 전에
먼저 정확한 전송을 보장하기 위해 상대방 컴퓨터와 사전에 세션을 수립하는 과정을 의미한다.
* TCP의 3-way Handshaking 과정
[STEP 1]
A클라이언트는 B서버에 접속을 요청하는 SYN 패킷을 보낸다. 이때 A클라이언트는 SYN을 보내고 SYN/ACK 응답을 기다리는 SYN_SENT 상태가 되는 것이다.
[STEP 2]
B서버는 SYN요청을 받고 A클라이언트에게 요청을 수락한다는 ACK 와 SYN flag 가 설정된 패킷을 발송하고 A가 다시 ACK으로 응답하기를 기다린다. 이때 B서버는 SYN_RECEIVED 상태가 된다.
[STEP 3]
A클라이언트는 B서버에게 ACK을 보내고 이후로부터는 연결이 이루어지고 데이터가 오가게 되는 것이다. 이때의 B서버 상태가 ESTABLISHED이다.
위와 같은 방식으로 통신하는 것이 신뢰성 있는 연결을 맺어 준다는 TCP의 3 Way handshake 방식이다.
3-Way handshake는 TCP의 연결을 초기화할 때 사용한다면, 4-Way handshake는 세션을 종료하기 위해 수행되는 절차입니다.
* TCP의 4-way Handshaking 과정
[STEP 1]
클라이언트가 연결을 종료하겠다는 FIN플래그를 전송한다.
[STEP 2]
서버는 일단 확인 메시지를 보내고 자신의 통신이 끝날 때까지 기다리는데 이 상태가 TIME_WAIT상태다.
[STEP 3]
서버가 통신이 끝났으면 연결이 종료되었다고 클라이언트에게 FIN플래그를 전송한다.
[STEP 4]
클라이언트는 확인했다는 메시지를 보낸다.
그런데 만약 "Server에서 FIN을 전송하기 전에 전송한 패킷이 Routing 지연이나 패킷 유실로 인한 재전송 등으로 인해 FIN패킷보다 늦게 도착하는 상황"이 발생한다면 어떻게 될까요?
Client에서 세션을 종료시킨 후 뒤늦게 도착하는 패킷이 있다면 이 패킷은 Drop 되고 데이터는 유실될 것입니다.
이러한 현상에 대비하여 Client는 Server로부터 FIN을 수신하더라도 일정 시간(디폴트 240초) 동안 세션을 남겨놓고 잉여 패킷을 기다리는 과정을 거치게 되는데 이 과정을 "TIME_WAIT" 라고 합니다.
'네트워크 > 네트워크 정리' 카테고리의 다른 글
Https는 공개키? 대칭키? 비대칭키? (1) 2020.04.03 Get과 Post의 차이 (1) 2020.02.05 웹에서의 쿠키와 세션 (0) 2020.01.18 Http와 Https 의 차이 (0) 2020.01.18 TCP와 UDP (0) 2020.01.16