Maximální velikost segmentu - Maximum segment size

The maximální velikost segmentu (MSS) je parametr možnosti pole TCP záhlaví, které určuje největší množství dat specifikované v bajtů, které může počítač nebo komunikační zařízení přijímat najednou TCP segment. Nepočítá se to TCP hlavička nebo IP hlavička (na rozdíl například od MTU pro IP datagramy).[1] The IP datagram obsahující segment TCP může být samostatný v jednom paketu, nebo může být rekonstruován z několika roztříštěný kousky; v obou případech platí limit MSS pro celkové množství dat obsažených v konečném rekonstruovaném segmentu TCP.

Aby nedošlo k roztříštěnosti v IP vrstva, hostitel musí specifikovat maximální velikost segmentu rovnou největšímu datagramu IP, který hostitel zvládne po odečtení velikostí hlaviček IP a TCP.[2] Proto, IPv4 hostitelé jsou povinni zvládnout MSS 536 oktetů (= 576[3] - 20 - 20) a IPv6 hostitelé jsou povinni zvládnout MSS 1220 oktetů (= 1280[4] - 40 - 20).

Malé hodnoty MSS sníží nebo eliminují fragmentaci IP, ale povedou k vyšší nad hlavou.[5]

Každý směr toku dat může používat různé MSS.

Pro většinu uživatelů počítačů je možnost MSS stanovena operační systém.

Výchozí hodnota

Výchozí maximální velikost segmentu TCP je 536.[6] Pokud si hostitel přeje nastavit maximální velikost segmentu na jinou než výchozí hodnotu, je maximální velikost segmentu zadána jako volba TCP, zpočátku v TCP SYN paket během TCP handshake. Po navázání připojení nelze hodnotu změnit.[7]

Mezivrstvá komunikace

Aby bylo možné upozornit MSS na druhý konec, probíhá mezivrstvá komunikace následujícím způsobem:[8]

  • Síťový ovladač (ND) nebo rozhraní by měl znát Maximální přenosová jednotka (MTU) přímo připojené sítě.
  • IP by měl požádat síťový ovladač o maximální přenosovou jednotku.
  • TCP by měl požádat IP o maximální velikost datagramu datagramu (MDDS). Toto je MTU minus délka hlavičky IP (MDDS = MTU - IPHdrLen).
  • Při otevírání připojení může TCP odeslat možnost MSS s hodnotou rovnou: MDDS - TCPHdrLen. Jinými slovy, hodnota MSS k odeslání je: MSS = MTU - TCPHdrLen - IPHdrLen

Při odesílání segmentů TCP na druhý konec probíhá mezivrstvá komunikace následujícím způsobem:[9]

  • TCP by měl určit maximální velikost dat segmentu (MSDS) z výchozí nebo přijaté hodnoty možnosti MSS.
  • TCP by měl určit, zda je fragmentace zdroje možná (dotazem na IP) a žádoucí.
    • Pokud ano, může TCP předat IP, segmenty (včetně hlavičky TCP) až do MSDS + TCPHdrLen.
    • Pokud ne, může TCP předat IP, segmenty (včetně hlavičky TCP) až po menší z (MSDS + TCPHdrLen) a MDDS.
  • IP kontroluje délku dat předávaných TCP. Pokud je délka menší nebo rovna MDDS, IP připojí záhlaví IP a předá jej ND. Jinak musí IP provést fragmentaci zdroje.

MSS a MTU

MSS je někdy sjednocen s MTU / PMTU, což je charakteristika podkladu odkazová vrstva, zatímco MSS platí konkrétně pro TCP, a proto transportní vrstva. Oba jsou podobné v tom, že omezují maximální velikost užitečného zatížení neseného jejich příslušnými datová jednotka protokolu (rámec pro MTU, segment TCP pro MSS) a související, protože MSS nemůže překročit MTU pro jeho podkladový odkaz (s přihlédnutím k režii všech záhlaví přidaných vrstvami pod TCP). Rozdíl, kromě aplikace na různé vrstvy, je však v tom, že MSS může mít jinou hodnotu v obou směrech a také to, že rámce překračující MTU mohou nakonec být fragmentovány transportní vrstva, zatímco segmenty přesahující MSS jsou jednoduše zahozeny.

Další čtení

  • Comer, Douglas E. (2006). Internetworking s TCP / IP. Sv. 1 (5 / ed.). Upper Saddle River, NJ, USA: Prentice Hall.
  • Kozierok, Charles M. (2005-09-20). Průvodce TCP / IP (3.0 ed.). Citováno 2011-09-08.

Viz také

Reference

  1. ^ RFC 879, strana 2, část 3, „MSS počítá v segmentu pouze datové oktety, nepočítá záhlaví TCP ani záhlaví IP.“
  2. ^ RFC 2460, strana 28, oddíl 8.3
  3. ^ RFC 879, strana 1, část 1
  4. ^ RFC 2460, strana 24, část 5
  5. ^ Průvodce TCP / IP, Maximální velikost segmentu TCP (MSS) a vztah k velikosti datagramu IP
  6. ^ RFC 879, strana 1, část 1, „Výchozí maximální velikost segmentu TCP je 536.“
  7. ^ RFC 793, strana 19, část 3.1, „Toto pole musí být zasláno pouze v počátečním požadavku na připojení (tj. v segmentech s nastaveným ovládacím bitem SYN).“
  8. ^ RFC 879, strana 1, část 11
  9. ^ RFC 879, strana 1, část 11