Computer-nettverk1. ReferansemodellerKilde: Tanenbaum.For å redusere kompleksiteten av designet, er de fleste nettverk organisert som en serie av lag, der hvert lag bygger på laget under. Hvert lag tilbyr altså tjenester til laget over.
For at lagene skal kunne snakke med hverandre, må man ha blitt enige om et sett med regler angående grensenittet. Laget n+1 sender gjerne en IDU (Interface Data Unit) til laget n gjennom SAP. IDU'en består at en SDU (Service Data Unit) og kontroll-informasjon. For å få overført SDUen, kan det hende lag n må dele den opp i flere biter. Hver bit får sin header og blir sendt som en separat PDU (Protocol Data Unit). Service-primitiver
1.1 OSI
1.1.1 Det fysiske lagetDet fyiske laget transporterer rå data (bits) over en kommunikasjonskanal. Hovedpoenget er at når man har sendt en 1-bit, skal det komme frem en 1-bit og ikke en 0-bit. Det man spør seg om er her typisk hvor mange volt som skal brukes for å representere 1 og hvor mange som skal representere 0, hvor mange mikrosekunder en bit varer, om man kan sende samtidig i begge retninger, hvordan forbindelsen blir etablert og hvordan den tas ned, hvor mange pins nettverkskoplingen har og hva hver pin brukes til.1.1.2 DatalinjelagetDatalinjelaget (data link layer) tar den rå bitstrømmen fra det fysiske laget og gjør så den virker fri for uoppdagede transmisjonsfeil for nettverkslaget. Dette gjør den ved å be senderen bryte input-dataene opp i data-rammer (data frames), sende rammene sekvensielt, og prosessere 'acknowledgement'-rammene som blir sendt tilbake fra mottakeren. For å gjenkjenne hvor en ramme starter og stopper, kan man for eksempel starte og ende hver ramme med et spesielt bit-mønster (bit pattern). Hvis disse bit-mønstrene tilfeldigvis skulle finnes inne i dataene, må man ta spesielle forhåndsregler så det ikke blir oppfattet som start/slutt på en ramme.Det er opp til datalinjelaget å å løse problemer med ødelagte, forsvunne og duplikate rammer. I tillegg har laget ofte en viss mulighet for å regulere trafikken, slik at en rask sender ikke sender altfor mye data til en treg mottaker. Hvis man kan sende data i begge retninger, kan det oppstå problemer hvis man skal sende en 'acknowledgement' fra A til B, samtidig som man prøver å sende data fra B til A. En løsning er piggybacking. Broadcast-nettverk har en ekstra problem i datalinjelaget: hvordan skal
man kontrollere tilgangen til den delte kanalen? Et spesielt underlag (sublayer)
av datalinjelaget, medium-aksess-laget, tar seg av dette.
1.1.3 NettverkslagetNettverkslaget finner ut hvor man skal sende en pakke for å få den helt fra A til B. Laget må vite hvor det skal sende pakken videre, ikke bare i riktig retning, men også utenom routere som har for mye trafikk. Nettverkslaget teller ofte også pakker fra forskjellige kunder, slik at det kan tas betalt for nettverkstrafikken. I tillegg må laget overkomme problemer med forskjellige nettverk, slik at data kan reise på heterogene, sammenkoplede nettverk (internet).I broadcast-nettverk er routingen så simpel at nettverkslaget
er tynt eller tilogmed ikke eksisterer.
1.1.4 TransportlagetTransportlagets funksjon er å ta imot data fra sesjonslaget (the session layer), dele dataene i mindre deler hvis det er nødvendig, sende disse til nettverkslaget, og forsikre seg om at alle delene kommer korrekt frem på den andre enden.Vanligvis oppretter transportlaget en nettverksforbindelse for hver transportforbindelse som sesjonslaget krever. Men hvis trasnportforbindelsen krever høy dataoverføringshastighet, kan transportlaget opprette flere nettverksforbindelser og dele datene mellom forbindelsene. På den annen side, hvis det å opprette en nettverksforbindelse er kostnadskrevende, kan transportlaget multiplekse flere transportforbindelser på den samme nettverksforbindelsen for å redusere kostnadene. Uansett skal multipleksingen være transparent for sesjonslaget. Transportlaget bestemmer også typen tjeneste det skal tilby sesjonslaget, for eksempel en feilfri point-to-point-kanal som leverer meldinger eller bytes i den rekkefølgen de er sendt. Transportlaget er det første laget i modellen som er ekte end-to-end. Lagene 1-3 er lenkede (de snakker med sine nærmeste naboer), mens 4-7 er end-to-end. Det er også en del flytkontroll i transportlaget. 1.1.5 Sesjonslaget1.1.6 Presentasjonslaget1.1.7 Applikasjonslaget1.2 TCP/IPBle først definert av Cerf & Kahn i 1974.1.2.1 Internet-lagetEt pakkesvitsjet nettverk basert på et forbindelsesløst internettverkslag. Dette lagets jobb er å la maskiner (hosts) sende pakker til nettverket slik at de kan reise uavhengig av hverandre til et mål (muligens på et annet nettverk). Pakkene kan godt komme frem i en annen rekkefølge enn de ble sendt ut, og det er da de øvre lagenes jobb å ordne pakkene igjen. Internet-laget definerer et pakkeformat og en protokoll kalt IP (Internet Protocol). Internet-laget skal altså levere pakkene til korrekt adresse, to viktige ingredienser her er routing og å unngå forstoppelse.1.2.2 TransportlagetTransportlagets oppgave er å la to maskiner føre en samtale. Transportlaget i TCP/IP-modellen har to definerte ende-til-ende protokoller: 1) TCP & 2) UDP.1.2.2.1 TCPTCP (Transmission Control Protocol) er en pålitelig forbindelsesorientert protokoll som lover å la en byte-strøm (byte stream) som kommer fra en maskin å bli levert uten feil til en annen maskin. Den fragmenterer den innkommende byte-strømmen (fra applikasjonslaget) og sender disse fragmentene til internet-laget, for så å sette dem sammen igjen på den andre siden. TCP tar seg også av flytkontroll, den sikrer at en rask sender ikke sender mer enn en treg mottaker kan ta imot.1.2.2.2 UDPUDP (User Datagram Protocol) er en upålitelig, forbindelsesløs protokoll. Den brukes ofte der det er viktigere å levere fort enn "riktig", f.eks. ved overføring av tale og video.1.2.3 ApplikasjonslagetApplikasjonslaget inneholder alle protokollene på høyere nivå: telnet, ftp (file transport protcol), SMTP (simple mail transport protcol), DNS (domain name server), gopher, wais, NNTP, HTTP (Hyper Text Tranfer Protocol), osv.
|