떵목이 2021. 10. 17. 20:03

* 이 글에 관련된 모든 내용은 Computer Networking A Top-Down Approach 7th에서 가져온 내용이다. *

 

저번 챕터2에서는 Application Layer에 대해 공부했었다.

이번 챕터부터는 그 하위레이어 Transport Layer에 대해서 공부하겠당

 

Transport Services


 

 

트랜스포트 레이어는 app간의 논리적인 소통을 담당한다.

 

이 레이어는 end system에서 작동한다.

sender side : app의 메시지를 segment단위로 잘라 하위레이어인 network layer로 보낸다.

receiver side : segment단위의 데이터를 message로 합쳐 상위레이어인 application layer로 보낸다.

 

 

 

나중에 다시 배우겠지만 네트워크 레이어는 end system간의 데이터 전송을 담당한다.

트랜스포트 레이어는 process간의 데이터 전송을 담당한다.

 

이전에 TCP와 UDP에 대해 간략하게 소개했었다.

이 두 프로토콜은 트랜스포트 레이어의 대표적인 프로토콜이다.

 

1. TCP(Transmission Control Protocol)

 - 연결지향

 - Reliable, ordered delivery

 - congestion control

 - flow control

 - Multiplexing/demultiplexing

2. UDP(User Datagram Protocol)

 - 비연결지향

 - Unreliable, unordered delivery

 - no-friils extesion of "best-effort" IP

 - Multiplexing/demultiplexing

 

Multiplexing/Demultiplexing


많은 application들은 하나의 transport layer protocol을 사용한다.

 

Demultiplexing

목적지의 호스트는 도착한 segement를 target application process에게 전달한다. 

각 세그먼트는 src와 dst의 포트넘버를 가지고 있다.

이때, 이 포트넘버는 프로세스를 indetify하기 위해 존재하는데, 각 프로세스들은 소통을 위해 포트넘버와 관련이 되어있다.

클라이언트 프로그램은

 - 클라이언트 호스트에서 실행되고 있는 트랜스포트 레이어 소프트웨어에 의해 자신의 포트넘버를 임의로 지정한다.

 - 이렇게 랜덤으로 지정한 포트넘버를 ephemeral port number라고 한다.

서버 프로그램은

 - well-known 포트넘버를 사용한다. (wellk-known포트넘버는 자주사용되어서 굳이 포트넘버를 IP에 붙여주지 않아도 기본값으로 설정되어있는 포트넘버이다)

 

Port Number


well-known ports

 - 0~1023 까지 지정이 되어있다.

Registered ports

 - 1024~49,151 까지 지정이 되어있다.

 - IANA에 의해 control되지 않는다. (IANA : 인터넷 할당번호를 관리하는 기관)

 - 그러나 중복을 막기위할때만 IANA에 등록될 수 있다. 

 - RFCs에 지정되지 않은 TCP/IP 어플리케이션을 사용할 때 사용된다.

Dynamic(private) ports

 - 49,152~65,535 까지 지정이 되어있다.

 - control되지도, 등록되지도 않는다.

 - 어떤 프로세스에도 사용될 수 있다 (ephemeral ports 포함) 

 

서버와 클라이언트에서의 포트넘버

 

 

- TCP socket은 src와 dst의 IP와 포트넘버를 모두 알아야 한다.

 

- UDP는 dst쪽의 IP와 포트넘버만 알면 된다.

 

즉 한 호스트로 온 서로 다른 데이터그램이 같은 port넘버를 가리키고 있으면 UDP는 다 받아버리지만 TCP는 src의 IP와 포트넘버도 맞아야 받는다.  

 

 

 

UDP에서의 demux

 

 

TCP에서의 demux

 

 

 

UDP (User Datagram Protocol)


이제 지금까지 맛만보았던 UDP에대해서 자세하게 알아보자.

 

UDP는 simple하고 비연결지향적인 인터넷 프로토콜이다.

connection이 필요없기 때문에 3-handshaking과정 또한 필요없다.

각 UDP 세그먼트들은 독립적으로 처리된다.

 

또한 UDP는 reliability를 보장하지 않는다.

세그먼트가 전송중에 손실될 수 있고, order또한 보장해주지 않는다.

또한 리시버의 buffer overflow를 막아주는 flow control도 없고, 라우터/스위치 등 네트워크의 혼잡을 제어헤주는 congestion control또한 없다.

게다가 에러를 체크하는 기능은 있지만 찾은 에러에 대해서 control하는 mechanism또한 없다.

(application layer에서 error recovery를 지원하기도 한다)

 

그렇다면 왜 UDP를 사용하는가?

 - connection과정이 필요없기에 overhead또한 없다.

 - error에 대한 recovery가 없기 때문에 매우 간단하다.

 - congetsion control이 없기 때문에 빠른 전송이 가능하다.

 - 1:1통신이 아닌 여러 peer와 통신이 가능하다.

 

이러한 장/단점때문에 UDP는 다음과 같은 곳에 사용된다.

 - streaming multimedia apps (로스에 치명적이지 않고, rate에 민감함)

 - RIP(Routing Internet Protocol) : 주기적으로 업데이트

 - DNS(Domain Name System) : connection set-up overhead가 없기 때문

 - SNMP(Simple Network Management Protocol) : 적은 overhead

 

UDP의 Header

UDP의 헤더는 다음과 같은 형식을 갖는다.

total length 는 헤더+데이터만큼의 길이이다.

error recovery를 지원하지 않기 때문에 sequence와 ACK를 위한 field는 없다.(TCP에서 다룰 예정)

checksum : header, data, pseudo-header를 이용해 에러를 체크하는 기능이다. IPv4에선 optional이지만 IPv6에선 필수이다. 만약 checksum을 통해 error를 확인하면 다른 처리는 하지 않고 그냥 제거해버린다.

 

UDP의 Pseudo-Header

 

 

수도헤더는 checksum 계산에 사용된다. (전송되는 정보는 아니다.)

 

UDP에서의 checksum

 

 

 

chceksum은 header, data 그리고 pseudo-header의 bit을 모두 더한 후 1's complement(1은 0으로 0은 1로)를 취한뒤 전송한다.

 

리시버는 받은 데이터의 합과 checksum을 더해 모든 자릿수가 1로 채워지지 않으면 에러로 간주하고 해당 datagram을 버린다.