Kuittaukset. Miksi? Miksi? Negatiiviset kuittaukset NAK-kuittauksilla voidaan nopeuttaa uudelleenlähettämistä. Ikkunankoko ACK

Samankaltaiset tiedostot
Miksi? Miksi? Kaksisuuntainen liikenne TCP-protokolla. Ikkunankoko. Valikoiva toisto: ikkuna 5, numeroavaruus 8

Ikkunankoko. Kun käytetty numeroavaruus on 0, 1,.. n ja eri numeroita siis käytettävissä n+1

Ikkunankoko. Kun käytetty numeroavaruus on 0, 1,.. n ja eri numeroita siis käytettävissä n+1

Kuittaukset. tähän saakka kaikki ok! Go-Back N. sanoma virheellinen tai puuttuu

Kuittaukset ACK. NAK-kuittaus. kumulatiivinen ACK. yksittäinen ACK. sanoma virheellinen tai puuttuu. tähän saakka kaikki ok!

Monimutkaisempi stop and wait -protokolla

Monimutkaisempi stop and wait -protokolla

Monimutkaisempi stop and wait -protokolla

Siirron optimointi. Optimointi on usein tarpeen: Silly window syndrome. Esimerkki jatkuu

Esimerkki jatkuu. <seq = 6, data = m6> <ack = 4, buf = 0> <ack = 4, buf = 1> <ack = 4, buf = 2> <ack = 6, buf = 0> <ack = 6, buf = 4> 1/31/

Siirron optimointi. Optimointi on usein tarpeen: Silly window syndrome

11/20/ Siirron optimointi

Esimerkki jatkuu. ajastin laukeaa, uudelleen sanoma 2. <seq = 6, data = m6>

6. Kuljetuskerros 6.1. Kuljetuspalvelu End- to- end

6. Kuljetuskerros 6.1. Kuljetuspalvelu

kynnysarvo (threshold) varoitusarvo = tästä lähtien syytä varoa ruuhkaa aluksi 64 K RTT

6. Kuljetuskerros 6.1. Kuljetuspalvelu End- to- end. kuljetuspalvelut parantavat verkkopalveluja Kuljetuskerroksen toiminta

kynnysarvo (threshold)

kynnysarvo (threshold)

3. Kuljetuskerros 3.1. Kuljetuspalvelu End- to- end

3. Kuljetuskerros 3.1.

3. Kuljetuskerros 3.1. Kuljetuspalvelu

3. Kuljetuskerros 3.1. Kuljetuspalvelu. Internetin kuljetuskerros. kuljetuspalvelut parantavat verkkopalveluja

3. Kuljetuskerros 3.1. Kuljetuspalvelu

peittää verkkokerroksen puutteet

3. Kuljetuskerros 3.1. Kuljetuspalvelu

TCP. TCP:n peruspiirteiden toiminta tarkemmin. TCP:n uusia piirteitä. osin vain harjoitustehtävissä

TCP:n peruspiirteiden toiminta tarkemmin. osin vain harjoitustehtävissä. TCP:n uusia piirteitä

TCP. TCP-optiot. Erilaisia suorituskykyongelmia. Aikaleima (timestamp) TCP:n peruspiirteiden toiminta tarkemmin. TCP:n uusia piirteitä.

3. Kuljetuskerros 3.1.

3. Kuljetuskerros 3.1. Kuljetuspalvelu End- to- end

Miten selain muodostaa TCP- tai UDP-yhteyden? TCP-osoite = IP-osoite + porttinumero ( tässä 80) SOCKET BIND (80) LISTEN ACCEPT. Connection Request

Kuljetuskerros. Tietokoneverkot. Matti Siekkinen Pasi Sarolahti

Tietoliikenne II (2 ov)

Tietoliikenne II (2 ov)

ELEC-C7241 Tietokoneverkot Kuljetuskerros

Asiakkaan toimenpiteet

on yksi keskeisimpiä toimintoja Internetin toiminnan varmistamiseksi Internetin ruuhkanhallinta pitkälti

Miten selain muodostaa TCP- tai UDP-yhteyden? TCP-osoite = IP-osoite + porttinumero ( tässä 80) SOCKET BIND (80) LISTEN ACCEPT. Connection Request

TCP. TCP-optiot. Erilaisia suorituskykyongelmia. Aikaleima (timestamp) TCP:n peruspiirteiden toiminta tarkemmin. TCP:n uusia piirteitä.

Tietoliikenne II (2 ov) Tietoliikenne II. Sisällysluettelo jatkuu. Alustava sisällysluettelo. Suoritus. Täydennystä Tietoliikenne I -kurssin asioihin

3. Kuljetuskerros 3.1. Kuljetuspalvelu

Tietoliikenne II (2 ov)

Ongelma 1: Ei saada kolmea toistokuittausta

Nopea uudelleenlähetys (Fast retransmit)

Nopea uudelleenlähetys (Fast retransmit)

TCP:n vuonohjaus (flow control)

Tietoliikenne II Kurssikoe

M. Allman, H. Balakrishnan, S. Floyd. January (Status: PROPOSED STANDARD) Lähettäjä ei saa kolmea toistokuittausta =>

Tietoliikenne II (2 ov) Sisällysluettelo jatkuu. Tietoliikenne II. Alustava sisällysluettelo. Suoritus

M. Allman, H. Balakrishnan, S. Floyd. January Lähettäjä ei saa kolmea toistokuittausta =>

3. Kuljetuskerros 3.1. Kuljetuspalvelu

Ratkaisu: Miksi lähetetään uusi paketti? SACK (Selective Acknowledgement) Nopea toipuminen ei onnistu! Limited Transmit

Kuljetuskerros. Kirja sivut: ,

Ruuhkanvalvonta on hankalaa!

Ruuhkanvalvonta on hankalaa!

Ruuhkanvalvonta on hankalaa!

Tietoliikenne II. Syksy 2005 Markku Kojo. Tietoliikenne II (2 ov,, 4 op) Page1. Markku Kojo Helsingin yliopisto Tietojenkäsittelytieteen laitos

Kuljetuskerroksen protokollat. Luotettava vai epäluotettava? Kuljetuskerroksen tarkoitus. Tietosähkeen kapselointi. Portit ja (de)multipleksaus

OSI ja Protokollapino

Tietoliikenteen perusteet

TCP/IP-protokollapino. Kuljetuskerros. Tämän luennon jälkeen. Sisältö. Matti Siekkinen. Ymmärrätte:

Selektiiviset kuittaukset (RFC 2018, RFC 3517)

Kuljetuskerroksen tehtävä. Kuljetuskerros UDP. UDP-kaappaus (DNS) DNS-haku, Ethernet-kehys <#>

Kuljetuskerroksen protokollat

Kuljetuskerroksen protokollat. Kuljetuskerroksen tarkoitus. Luotettava vai epäluotettava?

Kuljetuskerroksen protokollat

Kuljetuskerros. Matti Siekkinen. T Johdatus tietoliikenteeseen kevät 2011

Kuljetuskerros. CSE-C2400 Tietokoneverkot (osa 1) (osa 2) Matti Siekkinen. Tietokoneverkot 2014

Tehtävä 2: Tietoliikenneprotokolla

Kuljetuskerros. Matti Siekkinen. T Johdatus tietoliikenteeseen kevät 2013

Luento 6: Kuljetuskerros UDP & TCP TCP:n ruuhkanhallinta. Syksy 2014, Tiina Niklander Kurose&Ross: Ch3

Luento 6: Kuljetuskerros UDP & TCP TCP:n ruuhkanhallinta

Kuljetuskerros. CSE-C2400 Tietokoneverkot (osa 1) (osa 2) Matti Siekkinen. Tietokoneverkot 2014

Luento 6: Kuljetuskerros UDP & TCP TCP:n ruuhkanhallinta

Kuljetuskerroksen protokollat

Tietoliikenteen perusteet. Kuljetuskerros

Tietoliikenteen perusteet. Kuljetuskerros

Kuljetuspalvelu. Tietoliikenteen perusteet. Sisältöä. Kuljetuskerros. Kuljetuskerros. Kuljetuskerros. Internetin kuljetusprotokollat

Tietoliikenteen perusteet

Tietoliikenteen perusteet

Tietoliikenteen perusteet. Kuljetuskerros

Tietoliikenteen perusteet. Kuljetuskerros

Tietoliikenne II (2 ov) Syksy 2004 Liisa Marttinen

Tietoliikenne II (2 ov)

Tietoliikenne II. Tietoliikenne II (2 ov) Alustava sisällysluettelo. Sisällysluettelo jatkuu. Suoritus. Syksy 2003 Liisa Marttinen

Kuljetuspalvelu. Tietoliikenteen perusteet. Sisältöä. Kuljetuskerros. Kuljetuskerros. Kuljetuskerros. Internetin kuljetusprotokollat

Tietoliikenne II (2 ov)

Tietoliikenne II (2 ov) Syksy 2003 Liisa Marttinen

Luento 5: Kuljetuskerros luotettavan tiedonsiirron periaatteet. Syksy 2014, Tiina Niklander

Tietoliikenteen perusteet. Kuljetuskerros

Luento 5: Kuljetuskerros

Salausmenetelmät (ei käsitellä tällä kurssilla)

Tietoliikenteen perusteet. Kuljetuskerros

Vuonohjaus: ikkunamekanismi

3. Siirtoyhteyskerros linkkikerros (Data Link Layer) Virheiden hallinta. Vuonvalvonta. Kuittausviive Suunnitteluperiaatteita

3. Siirtoyhteyskerros linkkikerros (Data Link Layer)

3. Siirtoyhteyskerros

S Teletekniikan perusteet

Internet ja tietoverkot 2015 Harjoitus 5: (ISO/OSI-malli: Verkkokerros, TCP/IP-malli: internet-kerros)

Transkriptio:

ACK Kuittaukset kumulatiivinen ACK tähän saakka kaikki ok! Go-Back N yksittäinen ACK vain tämä ok! Valikoiva toisto NAK-kuittaus sanoma virheellinen tai puuttuu Negatiiviset kuittaukset NAK-kuittauksilla voidaan nopeuttaa uudelleenlähettämistä vastaanottaja ilmoittaa heti virheellisestä tai puuttuvasta kehyksestä ei ole tarpeen odottaa ajastimen laukeamista hyödyllinen, jos kuittausten saapumisaika vaihtelee paljon ajastinta vaikea asettaa oikein 5.10.2001 40 5.10.2001 41 NAK-kuittaukset voivat aiheuttaa turhia uudelleenlähetyksiä lähetys ja kuittaus menevät ristiin NAK-kuittauksen katoaminen ei haittaa implisiittinen uudelleenlähetys ei NAK-kuittauksia explisiittinen uudelleenlähetys käytetään NAK-kuittauksia Ikkunankoko Kun käytetty numeroavaruus on 0, 1,.. n ja eri numeroita siis käytettävissä n+1 yleensä jokin kakkosen potenssi» koska numerokentän koko k bittiä => käytössä 2**k numeroa ikkunan koko go back n :ssä voi olla korkeintaan n eli ainakin yhtä pienempi kuin numeroavaruus ikkunan koko valikoivassa toistossa voi olla korkeintaan (n+1)/2 korkeintaan puolet numeroavaruudesta 5.10.2001 42 5.10.2001 43 Miksi? Valikoiva toisto: ikkuna 5, numeroavaruus 8 0-4 Miksi? Valikoiva toisto: ikkuna 4, numeroavaruus 8 0-3 Kuittauksia voi kadota! ACK 0-4 Kuittauksia voi kadota! ACK 0-3 5-7, 0,1 0 ja 1 uutta vai uudelleenlähetystä? 4, 5, 1, 2 4, 5, 6 ja 7: täytyy olla uusi 0, 1, 2, 3: täytyy olla uudelleenlähetys 5.10.2001 44 5.10.2001 45

Kaksisuuntainen liikenne datakehys ja kuittauskehys kehyksessä sekä data että kuittaus piggypacking tehostaa lähetystä ongelma: kauanko kuittaaja odottaa dataa ennen pelkän kuittauksen lähettämistä? 3.5. TCP-protokolla yhteyden muodostus ja purku luotettavan tavuvirran toteuttaminen vuonvalvonta siirron optimointi TCP-segmentti ruuhkan valvonta TCP-palvelun käyttö 5.10.2001 46 5.10.2001 47 6.2.2. Yhteyden muodostus ja purku TCP:ssä TCP käyttää yhteyden muodostamiseen ja purkuun ns. kolminkertaista kättelyä (three-way handshake) välissä oleva verkko tekee yhteyden muodostamisen ja purun hankalaksi viivästyneet sanomat => sanomille elinaika sanomien numeroinnista sopiminen Bysanttilainen ongelma (two-army problem) hyökkään, jos olen varma, että sinäkin hyökkäät symmetrinen yhteyden purku = molemmat osapuolet tietävät, että toinenkin on varmasti purkanut yhteyden 5.10.2001 48 CR CR ACK DT DT DT CLOSE CLOSE ACK CR DT CLOSE Yhteyden muodostus ruuhkaisessa verkossa Jokainen paketti lähetetään kahteen kertaan Kun yhteys on purettu, viivästyneet kaksoiskappaleet saapuvat Ne tulkitaan uudeksi yhteydeksi, ja data otetaan vastaan kahteen kertaan! 5.10.2001 49 SYN = tahdistussanoma SYN, Seqnro=x SYN+ACK,Seqnro=y, ack=x+1 ACK,Seqnro=x+1, ack=y+1 Yhteyden muodostus Kolminkertainen kättely yhteyspyynnössä pyytäjän nro x vahvistuksessa sekä pyytäjän että suostujan järj.numero ensimmäisessä datalähetyksessä molemmat numerot #2 hyökkää vain, jos tietää minun saaneen vastaussanoman. #1 #2 Hyökätään aamulla kello 5! OK, siis kello 5! OK! Loogisesti ratkeamaton ongelma. Kaikki riippuu aina viimeisestä sanomasta, jonka perillemenoa ei voida taata! Entä, jos vastaus ei mene perille? Silloin #1 ei hyökkää! Bysanttilainen ongelma (two-army problem) 5.10.2001 50 5.10.2001 51

Kone 1 Kone 2 DATA CR CA DATA DATA DR Symmetrinen yhteyden purku DATA DR CR connection request CA connection accepted DR disconnect request Kuinka kauan odotettava mahdollista dataa kone 1:ltä? Entä jos kone 1 ei purakaan yhteyttä? 5.10.2001 52 Yhteyden purku molemmat suunnat puretaan erikseen TCP-segmentti FIN = 1 ei enää dataa lähetettävä kun saadan kuittaus => yhteys tähän suuntaan purettu yhteys kokonaan purettu, kun molemmat suunnat purettu purussa käytetään ajastimia 2 * paketin maksimaalinen elinikä 5.10.2001 53 Kone 1 FIN-lippu Kone 2 päällä lähetä DR (=lopetuspyyntö) ja aseta ajastin pura yhteys lähetä ACK DR DR ACK lähetä DR ja aseta ajastin pura yhteys Yhteyden purku kolminkertaista kättelyä käyttäen Virheettömyys ja järjestys Järjestysnumerot tavuvirta => tavunumerointi segmentin 1. tavun järjestysnumero yhteyden alussa satunnaiset numerot kuittaukset kumulatiivinen ACK, ei NAK-kuittausta kuittauksessa seuraavaksi odotettava tavu kuitataan tiheästi vähintään joka toinen 5.10.2001 54 5.10.2001 55 Go Back N -tyyppinen virheellisiä tai väärässä järjestyksessä tulleita ei hyväksytä ne voidaan myös tallettaa mutta ei välttämättä lähetä kaikkia virheellisestä lähtien uudestaan Myös ehdotettu valikoivan toiston tyyppistä kuittaamista SACK-kuitaus, joka kertoo, mitkä segmentit on vastaanotettu ok 5.10.2001 56 Toistokuittaukset Ensikuittaus tähän saakka kaikki OK! ensimmäisen kerran saatava toistokuittaus (duplicate ACK) väärässä järjestyksessä saatu segmentti tai virheellinen segmentti => toistetaan uudestaan jo annettu kuittaus NAK-kuittauksen korvike 3 toistokuittausta => segmentti kadonnut tai virheellinen 5.10.2001 57

TCP:n vuonvalvonta joustava liukuva ikkuna (sliding window) (credit-vuonvalvonta) vastaanottaja kertoo, kuinka paljon suostuu vastaanottamaan => kuittaus irroitettu vuonvalvonnasta AdvertisedWindow-kenttä paljonko saa lähettää = paljonko vastaanottajan puskureihin mahtuu myös ruuhkan valvonta rajoittaa lähettämistä 5.10.2001 58 A puskurit käytetty, A joutuu lopettamaan Esimerkki <ehdottaa 8 puskuria > <ack =0, buf = 4> <seq = 0, data = m0 > <seq = 1, data = m1 > <seq = 2, data = m2 > <ack = 1, buf = 3> <seq = 3, data = m3 > <seq = 4, data = m4> 5.10.2001 59 B lupa vain sanomille 0-3 kuittaus sanomista 0 ja 1, lupa sanomille 2-4, A ajastin laukeaa, uudelleen sanoma 2 lähettää sanoman 5 lähettää sanoman 6 jos lupa katoaa, jää odottamaan! ==> lukkiutumistilanne Esimerkki jatkuu <seq = 2, data = m2> <ack = 4, buf = 0> <ack = 4, buf = 1> <ack = 4, buf = 2> <seq = 5, data = m5> <seq = 6, data = m6> <ack = 6, buf = 0> <ack = 6, buf = 4> B kuittaa kaikki, mutta ei anna lupaa lähettää lupa lähettää yksi sanoma (= 5) lupa lähettää kaksi sanomaa (= 5 ja 6) kuittaa, mutta ei anna lähetyslupaa lähetyslupa sanomille 7-10 jos ilmoitus lisäpuskureista katoaa, lähettäjä lukkiutuu odotustilaan vastaanottaja voi luulla, ettei ole lähetettävää lukkiutumisen estämiseksi kun ikkunankoko = 0 lähettäjä ei saa lähettää, paitsi pikadataa (URG) yhden tavun kyselyn, jonka vastaanottaja kuittaa ja samalla ilmoittaa ikkunan koon => estää turhat lukkiutumiset 5.10.2001 60 5.10.2001 61 Siirron optimointi TCP saa optimoida lähettämisiään ei tarvitse lähettää heti kun data on tullut dataa kerätään puskuriin ja lähetetään sopivassa tilanteessa PUSH-lipun avulla sovellus ilmoittaa, että data on lähetettävä heti Optimointi on usein tarpeen: Interaktiivinen editori => merkki lähetetään heti 21 tavun TCP-segmentti => 41 tavun IP-paketti joka kuitataan 40 tavun IP-paketilla ilmoitus uudesta ikkunan koosta 40 tavun IPpaketilla kaiutetaan merkki vielä 41 tavun IP-paketilla yhden merkin käsittely => 162 tavun siirtäminen ja neljän segmentin lähettäminen 5.10.2001 62 5.10.2001 63

Ratkaisu: Naglen algoritmi jos data tulee tavuttain lähetä 1. tavu kerää sitä seuraavat tavut puskuriin ja lähetä vasta kun edellinen lähetys on kuitattu paitsi jos lähetettävää on suurimman segmentin verran tai puolet ikkunan koosta hankala, jos hiirtä liikutellaan Internetin kautta! 5.10.2001 64 Silly window syndrome Tilanteessa, jossa lähettäjältä dataa TCP:lle suurina lohkoina vastaanottajalle mahtuu vain tavu kerrallaan voi tuhota TCP:n suorituskyvyn koko data lähetetään tavu kerrallaan joka tavun välissä ilmoitus ikkunan koon kasvattamisesta yhdellä Siis: ei ilmoitusta yhdestä tavusta, lähettäjä ei lähetä yhtä tavua koko segmentti puolet puskurin koosta 5.10.2001 65 Silly winwow syndrome otsake otsake 1 tavu vastaanottaja puskuri täynnä sovellus lukee yhden tavun puskuriin mahtuu 1 tavu ilmoitetaan uusi ikkunan koko uusi tavu saapuu vastaanottaja puskuri täynnä segmentti TCP-segmentti 20 tavun otsake + optionaalinen osa dataosa voi puuttua segmentin kokoa rajoittaa MTU (Maximum transfer unit) verkon rajoitus maksimikoolle (muutama tuhat tavua) IP-paketin dataosa korkeintaan 65535 tavua liian isot segmentit paloitellaan joka palalle IP-otsake => yleisrasite kasvaa 5.10.2001 66 5.10.2001 67 Source port TCP head. length Checksum Checksum TCP-otsakkeen kentät Sequence number Destination port Acknowledgement number U A P R S F R C S S Y I Window size G K H T N N Urgent pointer Options (0 or more 32 bit words) Data (optional) 5.10.2001 68 TPC-segmentin otsakekentät Lähde- ja kohdeportit (Source port, Destination port) yhteyden päätepisteet portti + koneen IP-osoite => 48 bittinen TSAP Järjestysnumero (Sequence number) tavut numeroidaan => 32 bittiä segmentin ensimmäisen tavun numero Kuittausnumero (Acknowledgement number) seuraavaksi odotettu tavu TCP-otsakkeen pituus (TCP header length) mahdollisten optiokenttien takia 6 bitin käyttämätön kenttä 5.10.2001 69

6 lippubittiä URG onko pikadataa pikadatan sijainnin ilmoittaa pikadatakenttä (Urgent pointer) ACK onko kuittauskenttä käytössä PSH onko hetilähetettävää (pushed) dataa RST yhteyden uudelleenalustuspyyntö (reset), yleensä ongelmatilanne SYN käytetään yhteyttä muodostettaessa SYN =1, ACK = 0 connection request SYN =1, ACK = 1 connection accepted FIN käytetään yhteyden purkuun FIN =1 ei enää lähetettävää 5.10.2001 70 Ikkunan koko (window size) vaihteleva ikkunankoko kuittaus irroitettu lähetysluvasta Tarkistussumma (Checksum) lasketaan otsakkeelle, datalle ja ns. pseudootsakkeelle 5.10.2001 71 pseudo-otsake Source IP address Optiokenttä (options) voidaan lisätä piirteitä, joita ei ole varsinaisessa otsakkeessa suurin hyväksyttävä datakenttä Destination IP address 00000000 Protocol = 6 TCP/UDP segmentin pituus Auttaa havaitsemaan väärään osoitteeseen toimitetut paketit. ikkunan koon moninkertaistaminen (window scale) nopeille ja pitkän viipeen linjoille 64 ktavun ikkunan koko on liian pieni valikoivan toiston käyttö go back N :n tilalla vähentää turhia uudelleenlähetyksiä Sisältää IP-otsakkeen tietoja! 5.10.2001 72 5.10.2001 73 3.6. TCP:n ruuhkan valvonta Liikaa kuormitusta => verkko ruuhkautuu => hidastetaan lähettämistä Ruuhkan havaitseminen nykyisin siirtovirheet harvinaisia poikkeuksena langattomat verkot => uudelleenlähetykset johtuvat ruuhkasta uudelleenlähetysajastimen laukeaminen on merkki ruuhkasta ruuhkaikkuna paljonko tavuja (segmenttejä) lähettäjällä saa korkeintaan olla verkossa liikkeellä kuittaus => ko. tavut jo poistuneet verkosta tavuja kuittaukset 5.10.2001 74 5.10.2001 75

Ruuhkaikkunan koko? Lähettäjän on itse pääteltävä ja arvioitava sopiva ruuhkaikkunan koko kukaan muu ei sitä kerro! timeout => on ruuhkaa kuittaukset tulevat tasaisesti => ei ole ruuhkaa Dynaaminen ruuhkaikkunan koko: ruuhkaikkunaa kasvatetaan kunnes törmätään ruuhkaan sen jälkeen ruuhkaikkunaa pienennetään reilusti ja aletaan uudestaan kasvattaa ruuhkaikkunaa 5.10.2001 76 Hitaan aloituksen algoritmi (slow start) Algoritmi pyrkii löytämään sopivan ikkunan koon yhteyden alussa tai ruuhkatilanteen jälkeen mahdollisimman nopeasti ei ole niin kovin hidas, vaan alussa eksponentiaalinen! alussa ruuhkaikkuna = yksi segmentti kuitattu ruuhkaikkunallinen kasvattaa ruuhkaikkunan kaksinkertaiseksi 5.10.2001 77 lähettäjä datasegmentti ACK vastaanottaja kynnysarvo (threshold) varoitusarvo = tästä lähtien syytä varoa ruuhkaa aluksi 64 K kynnysarvoon saakka voidaan kasvattaa ruuhkaikkunaa eksponentiaalisesti kynnysarvon saavuttamisen jälkeen kasvatetaan ruuhkaikkunaa vain lineaarisesti = kasvatetaan kuittausten jälkeen vain yhdellä edetään hyvin varovaisesti! 5.10.2001 78 5.10.2001 79 jos ajastin ehtii laueta => ruuhkatilanne kynnysarvoksi puolet nykyisestä ruuhkaikkunan arvosta hitaalla aloituksella etsitään taas uusi sopiva ruuhkaikkunan arvo ruuhkaikkunan arvoksi 1 segmentti ruuhkaikkunaa kasvatetaan aluksi eksponentiaalisesti eli kaksinkertaistetaan kun ikkunallinen on kuitattu kynnysarvon saavuttamisen jälkeen kasvatetaan vain segmentti kerrallaan kunnes taas havaitaan ruuhka ja aloitetaan ruuhkaikkunan uuden arvon etsiminen Uudelleenlähetysjastimen hallinta uudelleenlähetysajastin (retransmission timer) asetetaan aina kun segmentti lähetetään ruuhkaa, jos kuittaus ei saavu ajoissa mikä on sopiva ajastimen aika? kuittaus aika vaihtelee suuresti vaihtelu on myös nopeaa dynaaminen arvo saadaan jatkuvien verkon suorituskykymittauksien perusteella 5.10.2001 80 5.10.2001 81

RTT arvio kiertoviiveelle (round-trip time) mitataan jokaisen lähetetyn segmentin kiertoviive M RTT = αrtt + (1-α)Μ, tyypillisesti α = 7/8 uudelleenlähetysajastimen arvo βrtt aluksi β oli aina 2 parannus: otetaan huomioon myös poikkeama D (deviation) oletetun ja saadun kiertoviiveen välillä RTT-M D = α D + (1- α) RTT-M ajastimen arvo = RTT +4*D uudelleenlähetysten vaikutus ajastimeen kumpaan segmenttiin kuittaus kohdistuu? Karnin algoritmi ei oteta huomioon uudelleenlähettyjen segmenttien kuittauksia RTT:n laskemisessa 5.10.2001 82 5.10.2001 83 Hidas aloitus: Lähetysmäärä kasvaa eksponentiaalisesti Ikkuna täyttyy ja lähettäjän täytyy odottaa kunnes kadonneen sanoman ajastin laukeaa Hidas aloitus: segmentti katoaa ja kuittausta ei tule => kadonneen segmentin ajastin laukeaa aikanaan Sitten aloitetaan taas hitaalla aloituksella