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

Samankaltaiset tiedostot
Luento 5: Kuljetuskerros

Tietoliikenteen perusteet

Tietoliikenteen perusteet. Kuljetuskerros

Tietoliikenteen perusteet. Kuljetuskerros

Tietoliikenteen perusteet. Kuljetuskerros

Tietoliikenteen perusteet. Kuljetuskerros

Tietoliikenteen perusteet. Kuljetuskerros

Chapter 3 Transport Layer. Kuljetuskerros

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

3. Kuljetuskerros 3.1. Kuljetuspalvelu End- to- end

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

Kappale 3, Siirto Taso. Luento-osuus 1 Käännös Mirja Hosionaho 100% Tietoverkot: ylhäältä alas lähestyminen

Monimutkaisempi stop and wait -protokolla

Monimutkaisempi stop and wait -protokolla

Monimutkaisempi stop and wait -protokolla

3. Kuljetuskerros 3.1. Kuljetuspalvelu

3. Kuljetuskerros 3.1.

Tietoliikenteen perusteet. Kuljetuskerros

Chapter 3: Transport Layer

3. Kuljetuskerros 3.1. Kuljetuspalvelu

Kappale 3 Kuljetustaso

Kuljetuskerros. Tietokoneverkot. Matti Siekkinen Pasi Sarolahti

100 % Kaisu Keskinen 3-1

ELEC-C7241 Tietokoneverkot Kuljetuskerros

Kuljetuskerros. Chapter 3 Transport Layer. Kuljetuskerros. Kuljetuspalvelut ja -protokollat. Kuljetuskerros vs. verkkokerros

Chapter 3 Transport Layer. Kuljetuskerros

Tehtävä 2: Tietoliikenneprotokolla

Kuljetuskerros. Chapter 3 Transport Layer. Kuljetuspalvelut ja -protokollat. Kuljetuskerros. Kuljetuskerros vs. verkkokerros

OSI ja Protokollapino

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

kynnysarvo (threshold)

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

kynnysarvo (threshold)

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

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ä

Internet ja tietoverkot. 3 Kuljetusprotokollat Luotettava ja epäluotettava tiedonsiirto

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

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

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

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

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

S Tietoliikennetekniikan perusteet. Pakettikytkentäiset verkot. Helsinki University of Technology Networking Laboratory

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

Luento 6: Kuljetuskerros UDP & TCP TCP:n ruuhkanhallinta

S Teletekniikan perusteet

Tietoliikenteen perusteet. Vähän kertausta. Tietoliikenteen perusteet /2009/ Liisa Marttinen 1

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

Kuljetuskerros. Kirja sivut: ,

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

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

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

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

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

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

3. Kuljetuskerros 3.1. Kuljetuspalvelu End- to- end

Luento 14: Kertausta. Syksy 2014, Tiina Niklander

Siltojen haitat. Yleisesti edut selvästi suuremmat kuin haitat 2/19/ Kytkin (switch) Erittäin suorituskykyisiä, moniporttisia siltoja

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

Luento 6: Kuljetuskerros UDP & TCP TCP:n ruuhkanhallinta

Tietoliikenteen perusteet. Vähän kertausta

Tietoliikenteen perusteet. Vähän kertausta

R R R RR. Kaikkien. pakettien. siirto yhden linkin yli. always on. Viimeisen siirto muiden linkkien yli. Sovellus: Kuljetus: Verkko: Linkki:

Tietoliikenteen perusteet

Tietoliikenteen perusteet

R R R RR. Kaikkien. pakettien. siirto yhden linkin yli. always on. Viimeisen siirto muiden linkkien yli. Sovellus: Kuljetus: Verkko: Linkki:

11/20/ Siirron optimointi

ITKP104 Tietoverkot - Teoria 3

3. Kuljetuskerros 3.1. Kuljetuspalvelu

5. Siirtoyhteyskerros linkkikerros (Data Link Layer)

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

Siirron optimointi. Optimointi on usein tarpeen: Silly window syndrome

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

TIETOLIIKENTEEN PERUSTEET kevät 2009

Kertausta: termejä ja käsitteitä

Luento 7: Verkkokerros verkkokerroksen tehtävät, IP-protokolla, reititin. Syksy 2014, Tiina Niklander

Asiakkaan toimenpiteet

5. Siirtoyhteyskerros linkkikerros (Data Link Layer)

1.4. Tietoliikenneohjelmistot eli protokollat

1.4. Tietoliikenneohjelmistot eli protokollat

1.4. Tietoliikenneohjelmistot eli protokollat. Protokollien kerrosrakenne. Mitä monimutkaisuutta?

Siltojen haitat Yleisesti edut selvästi suuremmat kuin haitat

peittää verkkokerroksen puutteet

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/

1. Tietokoneverkot ja Internet

3. Kuljetuskerros 3.1. Kuljetuspalvelu

1. Tietokoneverkot ja Internet Tietokoneesta tietoverkkoon. Keskuskone ja päätteet (=>-80-luvun alku) Keskuskone ja oheislaitteet

Tietoliikenteen perusteet: Kokeeseen tulevista asioista

Tietoliikenne II (2 ov)

3. Kuljetuskerros 3.1. Kuljetuspalvelu

Kuljetuskerroksen protokollat

Luento 2: Internetin ydin ja protokollapino

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

Kuljetuskerroksen protokollat

Luento 7: Verkkokerros

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

Tietoliikenne II (2 ov)

1. Tietokoneverkot ja Internet Tietokoneesta tietoverkkoon. Keskuskone ja oheislaitteet. Keskuskone ja päätteet (=>-80-luvun alku)

Transkriptio:

Tietoliikenteen perusteet Luento 5: Kuljetuskerros luotettavan tiedonsiirron periaatteet Syksy 2014, Tiina Niklander Kurose&Ross: Ch3 Pääasiallisesti kuvien J.F Kurose and K.W. Ross, All Rights Reserved Tietoliikenteen perusteet, syksy 2014 Tiina Niklander 16.2.2005

sanoma segmentti datagrammi kehys H l H n H n H t H t H t M M M M Lähettäjä (source) Sovellusk. Kuljetusk. Verkkok. Linkkik. Fyysinen k. Luennon sisältöä linkki fyysinen Kytkin (switch) message segment datagram frame H l Vastaanottaja (destination) H n H n H t H t H t M M M M application transport network link physical H l H n H n H t H t M M network link physical H n H t M Reititin (router) Tietoliikenteen perusteet, syksy 2014 Tiina Niklander 2

Sisältöä Kuljetuspalvelut Luotettavan kuljetuspalvelun periaatteet Yhteydetön kuljetuspalvelu, UDP Yhteydellinen kuljetuspalvelu, TCP Ruuhkanhallinta TCP:ssä Oppimistavoitteet: - Tuntee Internetin kuljetusprotokollien (UDP/TCP) toiminnallisuuden ja periaatteet - Osaa kuvata luotettavan kuljetuspalvelun ja vuonvalvonnan periaatteet ja toteutukset - Osata selittää TCPruuhkanhallinnan perusidean Tietoliikenteen perusteet, syksy 2014 Tiina Niklander 3

KULJETUSPALVELU Tietoliikenteen perusteet, syksy 2014 Tiina Niklander 4

Kuljetuskerros Tarjoaa kuljetuspalvelun prosessien välille Vain isäntäkoneissa Lähetys: Pilko sovelluskerroksen sanoma pienemmiksi segmenteiksi, jotka verkkokerros toimittaa perille. Vastaanotto: Kokoa segmentit sanomaksi, jonka sovellus lukee. Verkkokerros reitittää koneesta koneelle Segmentin koko s.e. verkkokerros pystyisi välittämään sellaisena application transport network data link physical network data link physical Fig 3.1 [KR12] network data link physical network data link physical network data link physical network data link physical application transport network data link physical Tietoliikenteen perusteet, syksy 2014 Tiina Niklander 5

Sovelluksen vaatimukset vs verkon ominaisuudet Sovellus edellyttää kuljetuspalvelulta Virheettömyyttä, luotettavuutta Järjestyksen säilymistä Kaksoiskappaleiden karsimista Mielivaltaisen pitkien sanomien sallimista Vuonvalvonnan mahdollistamista Verkkokerroksen palvelu voi kuitenkin Muuttaa segmentin bittejä tai kadottaa segmenttejä Toimittaa segmentit epäjärjestyksessä kuljetuskerrokselle Viivyttää segmenttejä satunnaisen pitkän ajan Luovuttaa kuljetuskerrokselle useita kopioita samasta segmentistä Rajoittaa segmentin kokoa Sovelluksen vaatimukset Kuljetuskerros pyrkii paikkaamaan verkkokerroksen puutteita Verkkokerroksen palvelut Kuljetuskerros peittää verkkokerroksen puutteita ja parantaa sovelluksen näkemää palvelun laatua Tietoliikenteen perusteet, syksy 2014 Tiina Niklander 6

Internetin kuljetusprotokollat TCP: luotettava, järjestyksen säilyttävä tavujen kuljetuspalvelu Virheenvalvonta (error control): Huomaa ja korjaa virheet, hylkää kaksoiskappaleet Vuonvalvonta (flow control): Älä ylikuormita vastaanottajaa Ruuhkanhallinta (congestion control): Älä ylikuormita verkkoa Yhteyden muodostaminen ja purku UDP: Ei-luotettava, ei-järjestyksen säilyttävä sanomien kuljetuspalvelu Välittää vain sanomia, ei pyri mitenkään parantamaan verkkokerroksen tarjoamaa palvelun laatua Luotettavuus jää sovelluskerroksen hoidettavaksi Kumpikaan kuljetuspalvelu ei anna takuita viiveelle tai siirtonopeudelle ( best effort ) Tietoliikenteen perusteet, syksy 2014 Tiina Niklander 7

Mikä kone / Mikä prosessi? Kuljetuskerros tarjoaa päästä-päähän yhteyden Prosessilta prosessille ( = pistokkeesta pistokkeeseen) Prosessi lukee ja kirjoittaa sanomia halutessaan Datan lisäksi on välitettävä osoitetietoja Vastaanottajan ja lähettäjän tiedot Eri koneiden prosessit voivat käyttää samaa palvelua Saman koneen prosessit voivat käyttää eri palveluita Kuljetuskerros: mikä prosessi = mikä portti Verkkokerros: mikä kone = mikä IP-osoite Porttinumero 16-bittinen: 0 65535 Portit 0 1024 on varattu kukin tietylle palvelulle (well known ports) Esim. www-palvelulle portti 80, SMTP-postipalvelulle portti 25 Tietoliikenteen perusteet, syksy 2014 Tiina Niklander 8

Segmenttien lomitus erottelu Lomitus lähettäjällä: Segmenttejä useasta pistokkeesta, liitä kuhunkin kuljetusotsake (käytetään erottelussa myöhemmin) lomitus (multiplexing) ja erottelu (demultiplexing) Erottelu vastaanottajalla: Välitä saapuva segmentti oikeaan pistokkeeseen, tieto löytyy otsakkeesta application P3 transport network link application P1 P2 transport network link physical application P4 transport network link socket process physical physical Fig 3.2 [KR12] Tietoliikenteen Tietoliikenteen perusteet, syksy perusteet 2014 2012, Tiina NIklander Tiina Niklander 9

Mikä kone / Mikä prosessi? Lähetys (asiakas) Kuljetuskerros Segmentin otsakkeessa lähde- ja kohdeprosessin porttinumero Antaa segmentin verkkokerroksen välitettäväksi TCP: huolehtii myös luotettavuudesta UDP: tarjoaa pelkän välityspalvelun Verkkokerros Paketin otsakkeessa lähde- ja kohdekoneen IP-osoite, reitittimet osaavat ohjata oikealle koneelle Kts Fig 3.3 & 4.13 [KR12] 32 bits source port # dest port # other header fields application data (message) TCP/UDP-segmentti Source IP Destination IP Other IP header fields TCP/UDP-segmentti IP-paketti Tietoliikenteen perusteet, syksy 2014 Tiina Niklander 10

Mikä kone / Mikä prosessi? Vastaanotto (palvelija) Verkkokerros Vastaanottaa IP-paketin Poistaa verkkokerroksen otsaketiedot Luovuttaa paketissa olleen segmentin kuljetuskerrokselle Kuljetuskerros Poistaa kuljetuskerroksen otsaketiedot Kokoaa yhteenkuuluvat segmentit sanomiksi (tavuvirraksi) Ohjaa sanoman (tavuvirran) oikealle prosessille (eli oikeaan pistokkeseen) porttinumeron avulla TCP: huolehtii myös luotettavuudesta UDP: tarjoaa pelkän välityspalvelun Kts Fig 3.3 & 4.13 [KR12] 32 bits source port # dest port # other header fields application data (message) TCP/UDP-segmentti Source IP Destination IP Other IP header fields TCP/UDP-segmentti IP-paketti Tietoliikenteen perusteet, syksy 2014 Tiina Niklander 11

Kaksi www-asiakasta ja palvelija TCP-yhteys: koneosoite + porttinumero UDP: koneosoite + porttinumero 6789 4567 8769 80 KR12: Fig 3.5 source port dest. port 8769 26145 source IP dest. IP B A Tietoliikenteen perusteet, syksy 2014 Tiina Niklander 12

LUOTETTAVAN KULJETUS- PALVELUN PERIAATTEET Tietoliikenteen perusteet, syksy 2014 Tiina Niklander 13

Luotettava tiedonsiirto? Lähettävä prosessi Vastaanottava prosessi DATA Sovelluskerros DATA Luotettava kuljetuskanava Kuljetuskerros Tietoliikenteen perusteet, syksy 2014 Tiina Niklander 14

Luotettava tiedonsiirto? Sovelluskerros Data Data Luotettava tiedonsiirtoprotokolla Miten saadaan luotettavaksi? Luotettava tiedonsiirtoprotokolla Segmentti Kuljetuskerros Segmentti Epäluotettava kanava Verkkokerros Bittivirheitä, segmenttejä katoaa, segmentit väärässä järjestyksessä Tietoliikenteen perusteet, syksy 2014 Tiina Niklander 15

Kuinka saada luotettavaksi? Tarkastellaan yleisesti luotettavan tiedonsiirron ongelmia ja erilaisia ratkaisuyrityksiä Edeten ideaalitilanteesta yhä ongelmaisempaan Käyttäen äärellisiä tila-automaatteja lähettäjän ja vastaanottajan toiminnan kuvaamiseksi LaMa:n termi: Tilasiirtymäjärjestelmä Siirtymän aiheuttama tapahtuma Toiminnot siirryttäessä Tapahtuma määrää yksikäsitteisesti seuraavan tilasiirtymän Tila 1 tapahtuma toiminnot Tila 2 Tietoliikenteen perusteet, syksy 2014 Tiina Niklander 16

Ideaalitilanne ( rtd1.0) Oletus: siirtokanava on täysin luotettava Ei bittivirheitä, ei katoavia paketteja, ei epäjärjestystä Luotettava kuljetuspalvelu = Lähettäjä kirjoittaa datan kanavaan, Vastaanottaja lukee datan kanavasta Wait for call from above rdt_send(data) packet = make_pkt(data) udt_send(packet) Wait for call from below rdt_rcv(packet) extract (packet,data) deliver_data(data) lähettäjä vastaanottaja Fig 3.9 [KR12] Tietoliikenteen perusteet, syksy 2014 Tiina Niklander 17

Tila-automaattien automaattien tapahtumia (kalvot ja kirja) rdt_send(): kutsutaan yläpuolelta (esim. Sovellus). Kutsussa tulee välitettävä data. deliver_data(): rdt kutsuu. Kutsussa välitetään data yläpuolelle. send side receive side udt_send(): rdt kutsuu. Kutsussa paketti epäluotettavan kanavan kautta vastaanottajalle rdt_rcv(): kutsutaan, kun paketti saapuu kanavasta vastaanottajalle Tietoliikenteen perusteet, syksy 2014 Tiina Niklander 18

Vain bittivirheitä ( rdt2.0) Oletus: Voi olla vain bittivirheitä Bitti voi kääntyä siirron aikana Siirto ei kadota paketteja Kuinka toipua? Kuittaukset: vastaanottaja kuittaa ACK:lla virheettömän paketin, NAK-kuittaus, jos paketti on virheellinen + hylkää Jos NAK, niin lähettäjä lähettää paketin uudelleen Luotettava kuljetuspalvelu Virheen huomaaminen: tarkistussumma Palaute vastaanottajalta: kuittaussanoma (ACK / NAK) Uudelleenlähetys: dataa puskuroitava Stop-and-wait-protokolla ACK Positive acknowledgment NAK Negative acknowledgment Lähettäjä odottaa kuittausta ennenkuin lähettää seuraavan Tietoliikenteen perusteet, syksy 2014 Tiina Niklander 19

Rtd 2.0: Vain bittivirheitä Fig 3.10 [KR12] sender receiver rdt_send(data) sndpkt = make_pkt(data, checksum) udt_send(sndpkt) rdt_rcv(rcvpkt) && isnak(rcvpkt) Wait for call from above Wait for ACK or NAK udt_send(sndpkt) rdt_rcv(rcvpkt) && corrupt(rcvpkt) udt_send(nak) Wait for call from below rdt_rcv(rcvpkt) && isack(rcvpkt) rdt_rcv(rcvpkt) && notcorrupt(rcvpkt) extract(rcvpkt,data) deliver_data(data) udt_send(ack) Tietoliikenteen perusteet, syksy 2014 Tiina Niklander 20

rdt2.0: Toiminta, kun ei ole virhettä Fig 3.10 [KR12] sender receiver rdt_send(data) snkpkt = make_pkt(data, checksum) udt_send(sndpkt) rdt_rcv(rcvpkt) && isnak(rcvpkt) Wait for call from above Wait for ACK or NAK udt_send(sndpkt) rdt_rcv(rcvpkt) && corrupt(rcvpkt) udt_send(nak) Wait for call from below rdt_rcv(rcvpkt) && isack(rcvpkt) rdt_rcv(rcvpkt) && notcorrupt(rcvpkt) extract(rcvpkt,data) deliver_data(data) udt_send(ack) Tietoliikenteen perusteet, syksy 2014 Tiina Niklander 21

rdt2.0: Toiminta virhetilanteessa Fig 3.10 [KR12] sender receiver rdt_send(data) snkpkt = make_pkt(data, checksum) udt_send(sndpkt) rdt_rcv(rcvpkt) && isnak(rcvpkt) Wait for call from above Wait for ACK or NAK udt_send(sndpkt) rdt_rcv(rcvpkt) && corrupt(rcvpkt) udt_send(nak) Wait for call from below rdt_rcv(rcvpkt) && isack(rcvpkt) rdt_rcv(rcvpkt) && notcorrupt(rcvpkt) extract(rcvpkt,data) deliver_data(data) udt_send(ack) Tietoliikenteen perusteet, syksy 2014 Tiina Niklander 22

rdt2.0: Missä voi mennä väärin? Ei toimi, jos ACK/NAK -paketeissa bittivirheitä! Onko OK vai ei? Korjaus: ACK/NAK-paketteihin tarkistusbitit, jotta virhe huomataan Entä toipuminen? Jos kuittauksessa virhe, lähetetään paketti uudelleen Uudelleenlähetys voi tuottaa kaksoiskappaleen (dublicate), joka on huomattava ja hylättävä => Paketteihin järjestysnumero Kaksoiskappale: jos sama numero Vastaanottaja kuittaa normaalisti, mutta ei anna sovellukselle Tietoliikenteen perusteet, syksy 2014 Tiina Niklander 23

Versio rdt2.1: enemmän bittivirheitä Lähettäjä: Lisää pakettiin järj.nro (numerot 0 ja 1 riittävät tässä protokollassa. Miksi?) Ns. vuorotteleva bitti Tarkista, että ACK/NAK ei ole korruptoitunut Tilakaaviossa nyt kaksinkertaisesti tiloja Kaavion tilan muistettava paketin numero Säilytä kopio lähetetystä paketista Vastaanottaja: Tarkista, ettei ole kaksoiskappale Kaavion tilan muistettava seuraavan paketin numero: 0 vai 1 Myös kaksoiskappale kuitattava, koska ei tiedä menikö edellinen kuittaus perille Tietoliikenteen perusteet, syksy 2014 Tiina Niklander 24

rdt2.1: Lähettäjän tila-automaattiautomaatti Fig 3.11 [KR12] Paketin lähetys rdt_rcv(rcvpkt) && notcorrupt(rcvpkt) && isack(rcvpkt) rdt_rcv(rcvpkt) && ( corrupt(rcvpkt) isnak(rcvpkt) ) udt_send(sndpkt) rdt_send(data) sndpkt = make_pkt(0, data,checksum) udt_send(sndpkt) Wait for call 0 from above Wait for ACK or NAK 1 rdt_send(data) Wait for ACK or NAK 0 Wait for call 1 from above rdt_rcv(rcvpkt) && ( corrupt(rcvpkt) isnak(rcvpkt) ) udt_send(sndpkt) sndpkt = make_pkt(1, data, checksum) udt_send(sndpkt) rdt_rcv(rcvpkt) && notcorrupt(rcvpkt) && isack(rcvpkt) vikaa! Paketin lähetys ok! Tietoliikenteen perusteet, syksy 2014 Tiina Niklander 25

rdt2.1: Vastaanottajan automaatti rdt_rcv(rcvpkt) && (corrupt(rcvpkt)) odotettu rdt_rcv(rcvpkt) && notcorrupt(rcvpkt) && has_seq0(rcvpkt) extract(rcvpkt,data) deliver_data(data) sndpkt = make_pkt(ack, chksum) vikaantunut udt_send(sndpkt) rdt_rcv(rcvpkt) &&(corrupt(rcvpkt)) sndpkt = make_pkt(nak, chksum) udt_send(sndpkt) sndpkt = make_pkt(nak, chksum) udt_send(sndpkt) rdt_rcv(rcvpkt) && not corrupt(rcvpkt) && has_seq1(rcvpkt) Wait for 0 from below Wait for 1 from below sndpkt = make_pkt(ack, chksum) udt_send(sndpkt) rdt_rcv(rcvpkt) && notcorrupt(rcvpkt) && has_seq1(rcvpkt) extract(rcvpkt,data) deliver_data(data) sndpkt = make_pkt(ack, chksum) udt_send(sndpkt) tupla rdt_rcv(rcvpkt) && not corrupt(rcvpkt) && has_seq0(rcvpkt) sndpkt = make_pkt(ack, chksum) udt_send(sndpkt) odotettu Tietoliikenteen perusteet, syksy 2014 Tiina Niklander 26

Versio rdt2.2: vain ACK-kuittaus ja vain bittivirheitä Sama toiminnallisuus kuin edellä Käyttää vain ACK-kuittauksia Vastaanottaja kuittaa viimeksi kunnossa saamansa paketin Kuittaukseen on liitettävä kuitattavan paketin numero Jos samalle paketille (nro X) tulee useita ACKkuittauksia (duplicate ACK), niin sitä seuraava paketti (nro X+1) joko puuttuu tai on virheellinen ~NAK-kuittaus Lähetetään uudelleen sanoma X+1 Tietoliikenteen perusteet, syksy 2014 Tiina Niklander 27

rdt2.2: Bittivirheitä ja vain ACK-kuittaus sender FSM fragment vikaa! sndpkt = make_pkt(0, data, checksum) udt_send(sndpkt) Wait for call 0 from above rdt_rcv(rcvpkt) && (corrupt(rcvpkt) has_seq1(rcvpkt)) sndpkt = make_pkt (ACK1, chksum) udt_send(sndpkt) Wait for 0 from below rdt_send(data) Wait for ACK 0 rdt_rcv(rcvpkt) && (corrupt(rcvpkt) isack(rcvpkt,1) ) udt_send(sndpkt) rdt_rcv(rcvpkt) && notcorrupt(rcvpkt) && isack(rcvpkt,0) vikaa! ok! receiver FSM fragment rdt_rcv(rcvpkt) && notcorrupt(rcvpkt) && has_seq0(rcvpkt) ok! extract(rcvpkt,data) deliver_data(data) sndpkt = make_pkt(ack0, chksum) udt_send(sndpkt) Fig 3.13 & 3.14 [KR12] Tietoliikenteen perusteet, syksy 2014 Tiina Niklander 28

Paketteja voi kadota ( rtd 3.0) Oletus: Siirtokanava voi kadottaa paketteja Sekä datapaketteja että kuittauspaketteja voi kadota. Tarkistussumma, pakettinumero, ACK eivät vielä riitä! Miksi? Lähettäjä odottaa jonkin aikaa kuittausta Jos ei saavu, lähettää paketin uudelleen Ajastin laukaisee uudelleenlähetyksen Jos paketti (data / kuittaus) kuitenkin vain viivästyy eikä olekaan kadonnut Syntyy duplikaatti, joka havaitaan sanomanumeroinnin avulla Kuittauksessa mukana kuitatun paketin numero Tietoliikenteen perusteet, syksy 2014 Tiina Niklander 29

rdt3.0: vuorottelevan bitin protokolla rdt_rcv(rcvpkt) Wait for call 0from above rdt_rcv(rcvpkt) && notcorrupt(rcvpkt) && isack(rcvpkt,1) stop_timer timeout udt_send(sndpkt) start_timer rdt_rcv(rcvpkt) && ( corrupt(rcvpkt) isack(rcvpkt,0) ) rdt_send(data) sndpkt = make_pkt(0, data, checksum) udt_send(sndpkt) start_timer Wait for ACK1 Sender rdt_send(data) Wait for ACK0 Wait for call 1 from above sndpkt = make_pkt(1, data, checksum) udt_send(sndpkt) start_timer rdt_rcv(rcvpkt) && ( corrupt(rcvpkt) isack(rcvpkt,1) ) timeout udt_send(sndpkt) start_timer rdt_rcv(rcvpkt) && notcorrupt(rcvpkt) && isack(rcvpkt,0) stop_timer rdt_rcv(rcvpkt) Fig 3.15 [KR12] Tietoliikenteen perusteet, syksy 2014 Tiina Niklander 30

rdt3.0 toiminnassa Fig 3.16 [KR12] Tietoliikenteen perusteet, syksy 2014 Tiina Niklander 31

rdt3.0 toiminnassa Fig 3.16 [KR12] Tietoliikenteen perusteet, syksy 2014 Tiina Niklander 32

Protokollaversioiden piirteet (kooste) Ideaalitilanne (RDT 1.0) Yksinkertainen lähetys ja vastaanotto Vain bittivirheitä datapaketeissa (RDT 2.0) Mekanismit: virheen tunnistus/korjaus, ACK ja NAK signaalit Uudelleenlähetys NAK signaalilla Enemmän bittivirheitä (data+signaalit) (RDT 2.1) Mekanismit: virheen tunnistus/korjaus kaikille paketeille, järjestysnumerot paketeille Miksi? vääristynyt signaali voi aiheuttaa tuplalähetyksen, jota ei voi tunnistaa ilman numeroita Vain ACK käytössä (RDT 2.2) Lisätään järjestysnumero ACKiin Paketteja voi kadota (RDT 3.0) Mekanismit: virheen tunnistus/korjaus kaikille paketeille, järjestysnumerot paketeille (data ja ACK), ajastin Tietoliikenteen perusteet, syksy 2014 Tiina Niklander 33

rdt3.0: Tehokkuus? Esim: 1 Gbps linkki, 15 ms päästä-päähän etenemisviive eli RTT = 30 ms, 1 KB:n paketti T transmit = L (packet length in bits) R (transmission rate, bps) = 8kb/pkt 10**9 b/sec = 8 microsec U sender = L / R RTT + L / R =.008 30.008 = 0.00027 microsec Käyttöaste (utilization): se osa kokonaisajasta, jolloin lähettäjä lähettää (RTT+L/R on kokonaisaika lähetyksessä kun odotetaan ACK) 1KB paketti 30 ms:n välein -> 33kB/s nopeus 1 Gbps linkillä. Stop-and-wait-protokolla rajoittaa, ei linkin kyky siirtää dataa (linkin siirtonopeus) Tietoliikenteen perusteet, syksy 2014 Tiina Niklander 34

rdt3.0: stop-and-wait tehokkuus 1. bitti lähetetty t = t L = / R 0 Viim. bitti lähetetty sender receiver Fig 3.18a [KR12] RTT 1. bitti saapuu Viim. bitti saapuu, lähetä ACK ACK saapuu, lähetä seur. paketin, t = RTT + L / R U sender = L / R RTT + L / R =.008 30.008 = 0.00027 microsec Tietoliikenteen perusteet, syksy 2014 Tiina Niklander 35

rdtx.x: Liukuhihnaprotokollat Lähettäjä saa lähettää useita paketteja, vaikka ei ole saanut kuittauksia edeltäviin Numerointi (0,1) ei enää riitä, lisää numeroita tarvitaan Tarvitaan puskurointia molemmissa päissä Fig 3.17 [KR12] Tietoliikenteen perusteet, syksy 2014 Tiina Niklander 36

Liukuhihnoitus: käyttöasteen kasvattaminen sender Paketin ensimmäinen bitti, t = 0 Viimeinen bitti, t = L / R receiver Fig 3.18b [KR12] RTT ACK saapuu, lähetä seur. paketti, t = RTT + L / R 1. paketin 1. bitti saapuu 1.paketin viim. bitti saapuu, lähetä ACK 2. paketin viim. bitti saapuu,lähetä ACK 3. paketin viim. bitti saapuu, lähetä ACK Käyttöaste kasvaa kolminkertaiseksi, koska 3 pakettia hihnalla U sender = 3 * L / R RTT + L / R =.024 30.008 = 0.0008 microsecon ilman liukuhihnaa: 0.00027 Tietoliikenteen perusteet, syksy 2014 Tiina Niklander 37

Liukuva ikkuna (sliding window) Säätelee pakettien lähettämistä ja vastaanottoa, kertoo millä pakettinumeroilla on lähetetty/vastaanotettu, mistä saatu/lähetetty kuittaukset ja millä numeroilla voi vielä lähettää/vastaanottaa paketteja Ikkunan koko riippuu yhteyden tyypistä ja puskurien koosta 7 0 6 1 5 2 4 3 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24. Tietoliikenteen perusteet, syksy 2014 Tiina Niklander 38

Liukuva ikkuna Lähetysikkuna (sender window) Ikkunan koko = montako pakettia saa olla kuittaamatta Mitkä pakettinumerot on käytetty, mutta kuittaamatta Mitä pakettinumeroita voi vielä käyttää Lähettäjän on odotettava, jos kaikki ikkunan numerot on käytetty Kun kuittaus saapuu, ikkuna liukuu Seuraavat numerot tulevat luvallisiksi Vastaanottoikkuna (receiver window) Mitkä pakettinumerot otettu vastaan, mutta kuittaamatta Mitä pakettinumeroita lähettäjä saa vielä käyttää eli mitkä hyväksytään Jos saadussa paketissa on ikkunan viimeinen numero Ikkuna pysäyttää pakettien lähetyksen vastapäästä Ikkuna estää uusien pakettien vastaanoton Paketin kuittaus liu uttaa myös vastaanottajan ikkunaa Hyväksytään uusia pakettinumeroita Tietoliikenteen perusteet, syksy 2014 Tiina Niklander 39

Kun ikkunan koko on 1 Vain yksi paketti kuittaamattomana One Bit Sliding Window protokolla = stop-and-wait protokolla Pakettinumerot 0 ja 1 riittävät ACK ilmoittaa Joko seuraavaksi odotetun paketin numeron (esim.tcp) tai viimeksi vastaanotetun virheettömän paketin numeron ACK sisältää paketin numeron Kuittausduplikaatti ei voi kuitata väärää paketteja Tietoliikenteen perusteet, syksy 2014 Tiina Niklander 40

Virhetilanteen käsittely Entä, kun huomataan virhe? Monta muuta pakettia jo matkalla! Pakettiin ei tule kuittausta Paketti katosi tai virheellinen Kuittaus katosi tai virheellinen => Ajastin laukeaa aikanaan Go-Back-N (paluu N:ään) Paketit uudelleenlähetetään virheellisestä lähtien Selective Repeat (Valikoiva toisto) Lähetetään vain virheelliset paketit Tietoliikenteen perusteet, syksy 2014 Tiina Niklander 41

Go-Back-N Vastaanottaja hyväksyy paketit vain järjestyksessä Kuittaa järjestyksessä tulleen virheettömän paketin Hylkää kaikki puuttuvan tai virheellisen paketin jälkeiset paketit eikä lähetä niistä kuittauksia Kun lähettäjä ei saa pakettiin kuittausta Lähetysikkuna täyttyy ja estää uusien pakettien lähettämisen Lähettäjän ajastimet laukeavat Lähettäjä lähettää uudestaan kaikki viimeisen kuittauksen jälkeiset paketit Näiden kuittaukset siirtävät taas lähetysikkunaa Tehoton, jos paljon virheitä ja iso ikkuna Tietoliikenteen perusteet, syksy 2014 Tiina Niklander 42

Go-Back-N Kumulatiivinen ACK Lähetä ACK, jossa korkein järjestyksessä saadun kelvollisen paketin numero Tämä kuittaa kaikki pienemmällä numerolla lähetetyt paketit Jos välistä puuttuu paketti Lähetä uudestaan ACK, jossa korkein järjestyksessä saadun paketin numero (~ NAK) Tuplakuittaus (duplicate ACK) Parannus: => nopeampi reagointi puuttuvaan Fig 3.19 [KR12] Tietoliikenteen perusteet, syksy 2014 Tiina Niklander 43

Go-Back-N: Esimerkki Fig 3.22 [KR12] Kumulatiivinen kuittaus Ikkunankoko = 4 Väärä numero! Kuittaa viimeisen kunnollisen ja järjestyksessä saadun paketin. tuplakuitttaus Tietoliikenteen perusteet, syksy 2014 Tiina Niklander 44

Go-Back-N: lähettäjän tilakaavio Lähetyspyyntö sovellukselta: lähetetään, jos ikkuna sallii Alkuarvot (base = ikkunan alku) base=1 nextseqnum=1 rdt_rcv(rcvpkt) && corrupt(rcvpkt) Korruptoitunut kuittaus hylätään Fig 3.20 [KR12] rdt_send(data) if (nextseqnum < base+n) { sndpkt[nextseqnum] = make_pkt(nextseqnum,data,chksum) udt_send(sndpkt[nextseqnum]) if (base == nextseqnum) start_timer nextseqnum++ } else refuse_data(data) Wait rdt_rcv(rcvpkt) && notcorrupt(rcvpkt) base = getacknum(rcvpkt)+1 If (base == nextseqnum) stop_timer else start_timer timeout start_timer udt_send(sndpkt[base]) udt_send(sndpkt[base+1]) udt_send(sndpkt[nextseqnum-1]) Tässä vain yksi ajastin! Ajastin laukeaa, lähetä kaikki kuittaamattomat uudestaan Kuittaus siirtää ikkunaa Sender Tietoliikenteen perusteet, syksy 2014 Tiina Niklander 45

Go-Back-N: Vastaanottajan tilakaavio receiver rdt_rcv(rcvpkt) && notcurrupt(rcvpkt) && hasseqnum(rcvpkt,expectedseqnum) Paketti ok ja odotettu numero extract(rcvpkt,data) deliver_data(data) sndpkt=make_pkt(expectedseqnum,ack,chksum) udt_send(sndpkt) expectedseqnum++ Data sovellukselle, kuittaus lähettäjälle Seuraava pnumero++ Wait expectedseqnum=1 sndpkt = make_pkt(expectedseqnum,ack,chksum) default udt_send(sndpkt) Muuten sama kuittaus uudestaan alkuarvot Fig 3.21 [KR12] Tietoliikenteen perusteet, syksy 2014 Tiina Niklander 46

Valikoiva toisto (Selective Repeat) Valikoiva uudelleenlähetys Lähetä uudelleen vain virheellinen /puuttuva paketti Kuittaus jokaiselle kelvolliselle paketille Paketit sovellukselle oikeassa järjestyksessä Vastaanottajalla oltava puskuritilaa pakettien järjestämiseen Jos lähettäjä ei saa kuittausta paketista Lähetysikkunan täyttyminen pysäyttää lähettämisen Aikanaan ajastin laukeaa ja aiheuttaa uudelleenlähetyksen Jokaisella paketilla on oma ajastin Ikkuna liukuu nytkin tasaisesti Yksi puuttuva kuittaus voi pysäyttää lähetyksen Kun puuttuva paketti saatu, ikkuna liukuu kaikkien kuitattujen yli Tietoliikenteen perusteet, syksy 2014 Tiina Niklander 47

Valikoiva toisto Fig 3.23 [KR12] Tietoliikenteen perusteet, syksy 2014 Tiina Niklander 48

Esimerkki: Valikoiva toisto Jokainen sanoma kuitattava erikseen Paketin 2 katoaminen estää ikkunaa liikkumasta Fig 3.23 [KR12] Tietoliikenteen perusteet, syksy 2014 Tiina Niklander 49

Ikkunankoko n+1 kpl Pakettinumeroille varatun kentän koko vaikuttaa myös ikkunankokoon Yleensä jokin kakkosen potenssi Kentän koko k bittiä => käytössä 2**k pakettinumeroa Kun paketit numeroidaan 0, 1,, n, niin ikkunan koko saa olla korkeintaan: Go-Back-n: n (k bit sekvenssinumeroilla < 2 k -1) MIKSI NÄIN? Harjoitustehtävinä! Valikoiva toisto: (n+1)/2 (k bit sekv.num. < 2 k-1 ) Vastaanottajan pitää tietää onko kyse uusista paketeista vai uudelleenlähetyksistä Tietoliikenteen perusteet, syksy 2014 Tiina Niklander 50

Yhteenveto menetelmistä Tarkistussumma Ajastin Järjestysnumero Uudelleenlähetys vai uusi paketti Kuittaukset Positiiviset ACK, tuplakuittaukset Negatiiviset NAK Ikkunat, liukuhihnoitus Kts Table 3.1 [KR12] Tietoliikenteen perusteet, syksy 2014 Tiina Niklander 51

ACK vai NAK ACK ja NAK signaaleja voidaan yhdistellä TCP perustuu vain ACKiin TCP: Kumulatiivinen ACK Tupla ACK X = NAK X+1 Selektiivinen ACK Parempi toteuttaa oma NAK signaali, tehokkaampi Ei välttämättä tarvita NAKia Pelkkä NAK Tietoliikenteen perusteet, syksy 2014 Tiina Niklander 52