네트워크에 입력되는 트래픽 양이 네트워크가 처리할 수 있는 한도(capacity)를 초과할 경우 체증이 발생한다.
정상적으로는 input만큼 output이 나와야하지만, congestion 상태에서는 input이 늘어날수록 혼잡도 때문에 output이 떨어지는 상황이 발생한다.
패킷망은 트래픽의 흐름은 일정하지 않다 (교통망처럼). 회선망은 회선을 미리 할당하고 트래픽을 전송하기 때문에 회선이 없는 경우가 아니면 congestion이 발생하지 않는다.
보통은 capacity 이하로 트래픽이 유입되지만 특정 시간에는 capacity를 초과하기도 한다. 따라서 망의 트래픽 처리 용량 (capacity)를 최대 트래픽 전송율보다 크게 유지할 수 있으면 congestion을 피할 수 있다.
어느정도 해결하는 것이지 완전히 해결할 수는 없다.
📌 흐름 제어는 송신 호스트와 수신 호스트 간에 처리 속도 간의 문제 해결이다.
사전에 망에 입력되는 트래픽 양을 조절한다.
두 가지 단계로 이루어진다.
라우터에서 패킷을 전송할 때, 사전에 약속된 계약에 따라 패킷의 전송 순위를 결정한다. (priority control)
congestion이 발생할 때 트래픽 양을 감소시킨다.
○ Congestion의 발견 (detection)
Congestion이 발생하는 것을 인식한다.
패킷의 지연시간, 라우터의 버퍼의 길이 등을 계속 측정하며 congestion 초기 상태를 발견해낼 수 있다.
○ Congestion에 대한 대응 (notification / rate control)
트래픽을 과도하게 유발시키는 소스들이 체증이 해소될 때까지 트래픽을 보내는 것을 보류하도록 통보한다. (notification)
후방 압박 (backpressure)이나 초크(choke) 패킷 전송이 그 예이다.
📌 End-to-end congestion control
반응적 혼잡 제어를 수행하기에 적합한 계층은 네트워크 계층 (라우터)이라 할 수 있다. 하지만 인터넷 프로토콜에서는 혼잡 제어 임무를 TCP가 수행하도록 하고 있다.
TCP는 송신한 패킷에 대해서 ACK를 수신한다. 만약 정해진 시간이 지날 때까지 ACK가 도착하지 않으면 congestion이 발생한 것으로 판단한다. (timeout)
초기 윈도우는 1로 시작한다. 그리고 ACK를 받을 때마다 윈도우를 하나씩 늘려서 cwnd와 awnd 중 낮은 값이 될 때까지 늘려나간다.
initialize : cwnd = 1 (one maximum segment size)
for each segment that is acknowledge
cwnd = cwnd + 1 (until min(cwnd, awnd))
Congestion이 발생했을 때, rate를 조절하는 알고리즘이다.
TCP는 timeout이 될 때까지 ACK을 받지 못하면 congestion이 발생 것으로 판단하고, congestion avoidance를 수행한다.
Rate control
timeout이 발생하면 threshold를 반으로 감소시킨다. 그리고 cwnd를 1로 설정하고 threshold까지 slow-start를 진행한다. cwnd가 threshold를 넘으면 매 RTT마다 1씩 증가시킨다.
If (segment timeout)
1. see threshold = cwnd / 2
2. set cwnd = 1 and restart "slow-start" until (cwnd = threshold)
3. if (cwnd >= threshold)
cwnd = cwnd + 1 every roundtrip time
추후에 추가되었다.
동일한 ACK을 3개 받을 경우
- 동일한 ACK이 계속 도착한다는 것은 congestion으로 판단하지만, 그렇더라도 상태가 심각하지 않다고 해석할 수 있다.
- 그래서 congestion avoidance 보다는 좀 더 적극적으로 전송한다.
Fast Retransmit
Fast Recovery
보수적으로 조절을 한다.
패킷 로스를 관측하는 손실 기반 방식
손실 기반 방식은 패킷 로스를 관측하고 손실이 늘어나면 혼잡이 발생했다고 간주하고 전송량을 억제하는 방법이다.
ex) Reno, NewReno, H-TCP, BIC, CUBIC
RTT를 지표로 하는 지연 기반 방식
지연 기반 방식은 패킷의 RTT을 관측하고 RTT가 늘어나면 혼잡 상태가 된 것으로 판단하고 전송량을 줄인다.
ex) Vegas, Westwood, Fast TCP
양쪽 방식을 사용하는 하이브리드 방식
ex) Illinois, DCTCP, CTCP, YeAH
https://www.youtube.com/watch?v=4TvP_-3KBH4
https://velog.io/@jsj3282/TCP-흐름제어혼잡제어-오류제어
https://roka88.dev/114
TCP 혼잡 제어 알고리즘들
TCP의 흐름제어에 대해 설명해주세요
송신측과 수신측 사이의 데이터 처리 속도 차이(흐름)을 제어하기 위한 기법으로 데이터 처리 속도를 조절하여 수신자의 버퍼 오버플로우를 방지한다.
흐름을 제어하기 위해 수신버퍼가 현재 얼마나 데이터를 받을 수 있는지 알려주는 수신 윈도우 변수를 이용한다.
TCP의 혼잡제어에 대해 설명해주세요.
네트워크망의 혼잡을 악화시켜 통신에 충돌이 나게 하는 것을 줄이고, 한정된 자원을 잘 분배하여 원활히 돌아갈 수 있도록 제어하는 것이다.
만약 네트워크 혼잡이 예상되면 송신의 속도를 조절하여 혼잡 붕괴 현상이 일어나는 것을 막습니다.