Zpožděné potvrzení TCP - TCP delayed acknowledgment - Wikipedia

Zpožděné potvrzení TCP je technika používaná některými implementacemi protokol kontroly přenosu ve snaze zlepšit se výkon sítě. V podstatě několik ACK odpovědi lze kombinovat do jedné odpovědi, což snižuje režijní náklady protokolu. Za určitých okolností však může technika snížit výkon aplikace.

Metoda a výhody

Jak je popsáno v RFC 1122, hostitel může odložit odeslání odpovědi ACK až o 500 ms. Navíc s proudem příchozích segmentů plné velikosti by měly být zasílány odpovědi ACK pro každý druhý segment.

Zpožděné ACK mohou dát aplikaci příležitost aktualizovat Přijímací okno TCP a také případně poslat okamžitou odpověď spolu s ACK. Pro určité protokoly, jako je Telnet, zpožděné ACK mohou snížit počet odpovědí odeslaných serverem o faktor 3, a to kombinací ACK, aktualizace okna a dat odpovědí do jednoho segmentu.[1]

Problémy

Dodatečná doba čekání zavedená zpožděným ACK může způsobit další zpoždění při interakci s určitými aplikacemi a konfiguracemi. Li Naglův algoritmus je používán odesílající stranou, odesílatel bude do fronty ukládat data, dokud nebude přijat ACK. Pokud odesílatel neposílá dostatek dat k vyplnění maximální velikost segmentu (například pokud provede dva malé zápisy následované blokujícím čtením), přenos se pozastaví až do časového limitu zpoždění ACK. Linux 2.4.4+ podporuje a TCP_QUICKACK možnost zásuvky, která zakáže zpožděné ACK.[2]

Zvažte například situaci, kdy Bob odesílá data Carol. Bobova soketová vrstva má k odeslání méně dat než celý balíček. Podle algoritmu Nagla nebude odeslán, dokud neobdrží ACK za data, která již byla odeslána. Zároveň aplikační vrstva Carol nebude odesílat odpověď, dokud nezíská všechna data. Pokud Carol používá zpožděné ACK, její vrstva soketu nebude posílat ACK, dokud nebude dosaženo časového limitu.

Pokud aplikace přenáší data v menších blocích a očekává pravidelné odpovědi na potvrzení, může dojít k této negativní interakci. Aby se zabránilo tomuto zpoždění, potřebuje aplikační vrstva nepřetržitě odesílat data bez čekání na odpovědi na potvrzení. Alternativně může být Nagleův algoritmus deaktivován aplikací na straně odesílatele.

Reference

  1. ^ http://tools.ietf.org/html/rfc1122#page-96
  2. ^ „tcp (7) v systému Linux“. manpages.info. Citováno 9. května 2018.