Miten Internet toimii. Jyry Suvilehto T Johdatus tietoliikenteeseen ja multimediatekniikkaan kevät 2013



Samankaltaiset tiedostot
Miten Internet toimii. Jyry Suvilehto T Johdatus tietoliikenteeseen ja multimediatekniikkaan kevät 2010

Miten Internet toimii. Tuomas Aura T Johdatus tietoliikenteeseen kevät 2013

Miten Internet toimii. Jyry Suvilehto T Johdatus tietoliikenteeseen ja multimediatekniikkaan kevät 2011

Miten Internet toimii. Tuomas Aura T Johdatus tietoliikenteeseen kevät 2010

Miten Internet toimii. Jyry Suvilehto T Johdatus tietoliikenteeseen ja multimediatekniikkaan kevät 2014

Kertaus. Jyry Suvilehto T Johdatus tietoliikenteeseen ja multimediatekniikkaan kevät 2011

Kertaus. Jyry Suvilehto T Johdatus tietoliikenteeseen ja multimediatekniikkaan kevät 2013

Kertaus. Jyry Suvilehto T Johdatus tietoliikenteeseen ja multimediatekniikkaan kevät 2012

WWW-sivu. Miten Internet toimii? World Wide Web. HTML-koodi. HTTP-istunto URL <#>

Linkkikerros, tiedonsiirron perusteet. Jyry Suvilehto T Johdatus tietoliikenteeseen ja multimediatekniikkaan kevät 2013

Sovelluskerros: Socket API, WWW, sähköposti, DNS

Sovellukset Interne.ssä

Kuljetus- ja verkkokerrokset. Jyry Suvilehto T Johdatus tietoliikenteeseen ja multimediatekniikkaan kevät 2011

Kertaus. Jyry Suvilehto T Johdatus tietoliikenteeseen ja multimediatekniikkaan kevät 2014

Taustaa. CGI-ohjelmointi

Yhteenveto / kertaus. Tuomas Aura T Johdatus Tietoliikenteeseen kevät 2013

Miten Internet toimii?

Pertti Pennanen OSI 1 (4) EDUPOLI ICTPro

Tietoliikenne II (2 ov)

OSI ja Protokollapino

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

Yhteenveto / kertaus. Tuomas Aura T Johdatus tietoliikenteeseen kevät 2011

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

Sovelluskerros: Socket API, WWW, sähköposti, DNS

Yhteenveto / kertaus. Tuomas Aura T Johdatus Tietoliikenteeseen kevät 2012

3. Kuljetuskerros 3.1. Kuljetuspalvelu

Jyry Suvilehto T Johdatus tietoliikenteeseen ja multimediatekniikkaan kevät 2012

Miten Internet toimii?

Jyry Suvilehto T Johdatus tietoliikenteeseen ja multimediatekniikkaan kevät 2013

Internet ja tietoverkot 2015 Harjoitus 7: Kertaus

Siirto- ja verkkokerrokset. Jyry Suvilehto T Johdatus tietoliikenteeseen ja multimediatekniikkaan kevät 2014

Tietoliikenne II (2 ov)

Sovellukset Internetissä

S Tietoliikennetekniikan perusteet. Piirikytkentäinen evoluutio. Annukka Kiiski

Tiedon esitys tietokoneessa. Jyry Suvilehto T Johdatus tietoliikenteeseen ja multimediatekniikkaan kevät 2012

Tietoverkkojen turvallisuus. Tuomas Aura T Johdatus tietoliikenteeseen kevät 2012

Siltojen haitat Yleisesti edut selvästi suuremmat kuin haitat

ELEC-C7241 Tietokoneverkot Kuljetuskerros

1.1 Internetistä lyhyesti. Mikä Internet on? 1.2 Maailmanlaajuinen verkko

Tietoverkkojen turvallisuus. Tuomas Aura T Johdatus tietoliikenteeseen kevät 2011

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

S Teletekniikan perusteet

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

Kertausluento. Tuomas Aura T Johdatus tietoliikenteeseen kevät 2010

Linkkikerros, tiedonsiirron perusteet. Jyry Suvilehto T Johdatus tietoliikenteeseen ja multimediatekniikkaan kevät 2011

Linkkikerros, tiedonsiirron perusteet. Jyry Suvilehto T Johdatus tietoliikenteeseen ja multimediatekniikkaan kevät 2011

Tietoliikenne I (muuntokoulutettaville) 2 ov Syksy 2002 Luennot Liisa Marttinen 11/6/2002 1

Tietoverkkojen turvallisuus. Tuomas Aura T Johdatus tietoliikenteeseen kevät 2013

TCP/IP-protokollat ja DNS

Yhteenveto. CSE-C2400 Tietokoneverkot

Kuva maailmasta Pakettiverkot (Luento 1)

D-Link DSL-504T ADSL Reitittimen Asennusohje ver. 1.0

TCP/IP-protokollapino. Verkkokerros ja Internetprotokolla. Sisältö. Viime luennolla. Matti Siekkinen

Sovellusprotokolla on vain osa hajautettua sovellusta Esim. WWW

Web-sovellusten testaus

TW- EAV510 v2: WDS- TOIMINTO TW- EAV510 V2 LAITTEEN ja TW- LTE REITITTIMEN VÄLILLÄ. Oletus konfiguroinnissa on, että laitteet ovat tehdasasetuksilla

Sovelluskerros: Socket API, WWW, sähköposti, DNS

Tietoliikenne I (muuntokoulutettaville) 2 ov syksy 2003 Luennot Liisa Marttinen

Tietoliikenneohjelmointi. v. 0.01

TW- EAV510 JA TW- LTE REITITIN: WDS- VERKKO

2. Sovelluksia ja sovellusprotokollia

Luento 1. Jouni Ikonen - Jouni.Ikonen lut.fi

Mikä on internet, miten se toimii? Mauri Heinonen

Tietoliikenne I 2 ov kevät 2003

Tietoliikenne I 2 ov kevät 2004

Tietoliikenne I 2 ov kevät 2004

ELEC-C7241 Tietokoneverkot Sovelluskerros

Tietoliikenne I (muuntokoulutettaville) 2 ov syksy 2003 Luennot Liisa Marttinen

TVP 2003 kevätkurssi. Kertaus Otto Alhava

Jyry Suvilehto T Johdatus tietoliikenteeseen ja multimediatekniikkaan kevät 2010

S Tietoliikennetekniikan perusteet. Pakettikytkentäiset verkot. Tietoliikenne- ja tietoverkkontekniikan laitos

Järjestelmäarkkitehtuuri (TK081702)

T Hypermediadokumentin laatiminen. Sisältö. Tavoitteet. Mitä on www-ohjelmointi? Arkkitehtuuri (yleisesti) Interaktiivisuuden keinot

Laitteessa tulee olla ohjelmisto tai uudempi, tarvittaessa päivitä laite

Sovellusprotokolla on vain osa hajautettua sovellusta Esim. WWW

2. Sovelluksia ja sovellusprotokollia

2. Sovelluksia ja sovellusprotokollia

Tietokone. Tietokone ja ylläpito. Tietokone. Tietokone. Tietokone. Tietokone

ATK yrittäjän työvälineenä

Luennon sisältö. Protokolla eli yhteyskäytäntö (1) Verkon topologia

Tietoliikenteen perusteet

Antti Vähälummukka 2010

Tietoliikenteen perusteet

3. Laajakaistaliittymän asetukset / Windows XP

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

OSI malli. S Tietoliikenneverkot S Luento 2: L1, L2 ja L3 toiminteet

WWW-PALVELUN KÄYTTÖÖNOTTO LOUNEA OY

SSH Secure Shell & SSH File Transfer

Salaustekniikat. Tuomas Aura T Johdatus tietoliikenteeseen kevät 2010

3. Kuljetuskerros 3.1. Kuljetuspalvelu

Tietoliikenne I 2 ov kevät 2002

S Tietoliikennetekniikan perusteet. Piirikytkentäinen evoluutio

2. PEHMEÄ XHTML XRAJAHTML

1.4. Tietoliikenneohjelmistot eli protokollat

1.4. Tietoliikenneohjelmistot eli protokollat

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

IHTE 1900 Seittiviestintä (syksy 2007) VERKKOTEKNIIKKAA. Mikä on protokolla, IP osoite, nimipalvelu jne ja mihin näitä tarvitaan?

Tietoliikenteen perusteet

3 Verkkosaavutettavuuden tekniset perusteet

ICMP-sanomia. 3. IP-kerroksen muita protokollia ja mekanismeja ICMP (Internet Control Message Protocol)

Transkriptio:

Miten Internet toimii Jyry Suvilehto T-110.1100 Johdatus tietoliikenteeseen ja multimediatekniikkaan kevät 2013

Sisältö 1. Internet ylhäältä alas 2. Internetin protokollapino 3. Katse kohti tulevaisuutta Luento pohjautuu Tuomas Auran aloitusluentoon kurssilla T-110.2100 2

INTERNET YLHÄÄLTÄ ALAS 3

Asiakas (käyttäjä, työasema ja selainohjelma) Nettiselailu Palvelin (palvelinkone ja -ohjelma) Internet Asiakas/palvelin-malli Nimiarvaruus: URL http://www.cse.tkk.fi/~jsuvileh/jotime/ esimerkki.html on resurssi 4

Tiedon muoto Tietokoneiden käsittelemä tieto on määrämuotoista Esim. HTML = hypertekstin merkintäkieli <!DOCTYPE html PUBLIC '-//W3C//DTD XHTML 1.1//EN' 'http:// www.w3.org/tr/xhtml11/dtd/xhtml11.dtd'> <html xmlns='http://www.w3.org/1999/xhtml' xml:lang='fi'> <head> <title>esimerkki</title> </head> <body> <!-- Tämä on kommentti, se ei näy tekstissä --> <h1>otsikko</h1> <p>tämä on erittäin yksinkertainen webbisivu.</p> Sivun esimerkki.html lähdekoodi <div><img src="http://www.aalto.fi/style_aaltofi/img/aaltologo-3-fi.gif" alt="aalto-yliopiston logo"/></div> </body> </html> 5

Protokolla Tiedon siirtoon palvelimen ja asiakkaan välillä pitää sopia yhteyskäytäntö eli protokolla: lähetettävät viestit ja niiden otsakkeet tilakone: kuka lähettää mitä ja milloin tiedon muoto siirtotie Esim. HTTP = hypertekstin siirtoprotokolla Protokollista sovitaan standardointiorganisaatioissa: IETF, W3C, Oasis, ISO, IEEE, 3GPP, ITU, 6

Protokolladroidi Toinen merkitys sanalle protokolla sosiaalisen kanssakäymisen säännöstö Tavattaessa kätellään Kysymykseen vastataan Tuntemattomat esitellään toisilleen Tarkoitus sama, konteksti eri Ennalta sovittu toimintatapa, jota noudatetaan määritellyssä tilanteessa 7

Protokolla kannattaa noudattaa I d call on Anna if she d only broken the law, but she broke the rules. 8

Selaimelta palvelimelle: HTTP GET /jsuvileh/jotime/esimerkki.html HTTP/1.1 Host: www.cse.tkk.fi User-Agent: Mozilla/5.0 (Windows; U; Windows NT 6.1; en-us; rv:1.9.1.7) Gecko/20091221 Firefox/3.5.7 Accept: text/html,application/xhtml+xml,application/xml;q=0.9,*/*;q=0.8 Accept-Language: en-us,en;q=0.5 Accept-Encoding: gzip,deflate Accept-Charset: ISO-8859-1,utf-8;q=0.7,*;q=0.7 Keep-Alive: 300 Connection: keep-alive Palvelimelta selaimelle: HTTP/1.x 200 OK Date: Thu, 21 Jan 2010 12:57:12 GMT Server: Apache/1.3.41 (Unix) PHP/4.4.7 DAV/1.0.3 mod_ssl/2.8.31 OpenSSL/0.9.8j Etag: "2f80a6-1d9-4b585a30"Accept-Ranges: bytes Keep-Alive: timeout=15, max=100 Connection: Keep-Alive Content-Type: text/html HTTP-pyyntö HTTP-pyynnön otsakkeet HTTP-vastaus HTTP-vastauksen otsakkeet Tyypillinen asiakas/palvelin- <!DOCTYPE html PUBLIC '-//W3C//DTD XHTML 1.1//EN' 'http://www.w3.org/tr/xhtml11/dtd/xhtml11.dtd'> <html xmlns='http://www.w3.org/1999/xhtml' xml:lang='fi'> <head> <title>esimerkki</title> protokollan </head> <body> rakenne: pyyntö <!-- Tämä on kommentti, se ei näy tekstissä --> <h1>otsikko</h1> <p>tämä on erittäin ja yksinkertainen vastaus webbisivu.</p> <div><img src="http://www.aalto.fi/style_aaltofi/img/aalto-logo-1-fi.gif" Data(HTML) alt="aalto-yliopiston logo"/></div> </body> </html> 9

Selaimelta palvelimelle: HTTP GET /jsuvileh/jotime/esimerkki.html HTTP/1.1 Host: www.cse.tkk.fi User-Agent: Mozilla/5.0 (Windows; U; Windows NT 6.1; en-us; rv:1.9.1.7) Gecko/20091221 Firefox/3.5.7 Accept: text/html,application/xhtml+xml,application/xml;q=0.9,*/*;q=0.8 Accept-Language: Host: www.cse.tkk.fi en-us,en;q=0.5 Accept-Encoding: gzip,deflate HTTP-pyynnön Accept-Charset: ISO-8859-1,utf-8;q=0.7,*;q=0.7 Keep-Alive: 300 otsakkeet Connection: keep-alive Palvelimelta selaimelle: HTTP-pyyntö GET /jsuvileh/jotime/esimerkki.html HTTP/1.1 HTTP/1.x 200 OK Date: Thu, 21 Jan 2010 12:57:12 GMT Server: Apache/1.3.41 (Unix) PHP/4.4.7 DAV/1.0.3 mod_ssl/2.8.31 OpenSSL/0.9.8j Etag: "2f80a6-1d9-4b585a30"Accept-Ranges: bytes Keep-Alive: timeout=15, max=100 Connection: Keep-Alive Content-Type: text/html User-Agent: Mozilla/5.0 (Windows; U; Windows NT 6.1; en-us; rv:1.9.1.7) Gecko/20091221 Firefox/ 3.5.7 HTTP-vastaus Accept:text/html,application/xhtml +xml,application/xml;q=0.9,*/*;q=0.8 HTTP-vastauksen Accept-Language: Tyypillinen en-us,en;q=0.5 otsakkeet Accept-Encoding: asiakas/palvelin- gzip,deflate Accept-Charset: ISO-8859-1,utf-8;q=0.7,*;q=0.7 <!DOCTYPE html PUBLIC '-//W3C//DTD XHTML 1.1//EN' 'http://www.w3.org/tr/xhtml11/dtd/xhtml11.dtd'> <html xmlns='http://www.w3.org/1999/xhtml' xml:lang='fi'> <head> <title>esimerkki</title> protokollan </head> <body> Keep-Alive: rakenne: <!-- Tämä on kommentti, se 300 pyyntö ei näy tekstissä --> <h1>otsikko</h1> Connection: <p>tämä erittäin ja yksinkertainen vastaus keep-alive webbisivu.</p> <div><img src="http://www.aalto.fi/style_aaltofi/img/aalto-logo-1-fi.gif" Data(HTML) alt="aalto-yliopiston logo"/></div> </body> </html> 10

Selaimelta palvelimelle: HTTP/1.x 200 OK HTTP GET /jsuvileh/jotime/esimerkki.html HTTP/1.1 Host: www.cse.tkk.fi User-Agent: Date: Mozilla/5.0 Thu, (Windows; 21 Jan U; Windows 2010 NT 6.1; 12:57:12 en-us; rv:1.9.1.7) Gecko/20091221 GMT Firefox/3.5.7 Accept: text/html,application/xhtml+xml,application/xml;q=0.9,*/*;q=0.8 Accept-Language: en-us,en;q=0.5 Accept-Encoding: Server: gzip,deflate Apache/1.3.41 (Unix) HTTP-pyynnön PHP/4.4.7 DAV/ Accept-Charset: ISO-8859-1,utf-8;q=0.7,*;q=0.7 Keep-Alive: 1.0.3 300 mod_ssl/2.8.31 OpenSSL/0.9.8j otsakkeet Connection: keep-alive Etag: "2f80a6-1d9-4b585a30 Palvelimelta selaimelle: Accept-Ranges: bytes HTTP/1.x 200 OK Date: Thu, 21 Jan 2010 12:57:12 GMT Server: Keep-Alive: Apache/1.3.41 (Unix) timeout=15, PHP/4.4.7 DAV/1.0.3 mod_ssl/2.8.31 max=100 OpenSSL/0.9.8j Etag: "2f80a6-1d9-4b585a30"Accept-Ranges: bytes Keep-Alive: timeout=15, max=100 Connection: Keep-Alive Keep-Alive Content-Type: text/html HTTP-pyyntö HTTP-vastaus HTTP-vastauksen otsakkeet Content-Type: Tyypillinen text/html asiakas/palvelin- <!DOCTYPE html PUBLIC '-//W3C//DTD XHTML 1.1//EN' 'http://www.w3.org/tr/xhtml11/dtd/xhtml11.dtd'> <html <!DOCTYPE xmlns='http://www.w3.org/1999/xhtml' html PUBLIC '-//W3C//DTD XHTML 1.1//EN' xml:lang='fi'> 'http://www.w3.org/tr/xhtml11/dtd/xhtml11.dtd'> <html <head> xmlns='http://www.w3.org/1999/xhtml' xml:lang='fi'> <head> <title>esimerkki</title> protokollan </head> <title>esimerkki</title> <body> </head> rakenne: pyyntö <body> <!-- Tämä on kommentti, se ei näy tekstissä --> <h1>otsikko</h1> <!-- Tämä on kommentti, se ei näy tekstissä --> <p>tämä on erittäin ja yksinkertainen vastaus <h1>otsikko</h1> webbisivu.</p> <div><img <p>tämä on src="http://www.aalto.fi/style_aaltofi/img/aalto-logo-1-fi.gif" erittäin yksinkertainen webbisivu.</p> Data(HTML) alt="aalto-yliopiston <div><img src="http://www.aalto.fi/style_aaltofi/img/aalto-logo-1-fi.gif" logo"/></div> </body> alt="aalto-yliopiston logo"/></div> </html> </body> </html> 11

HTTP HTTP eli Hypertext transfer protocol Hyperteksti on nimitys tekstille, jossa on hyperlinkkejä, käytännösä HTML/XML tässä yhteydessä HTTP yli voidaan sinänsä siirtää mitä tahansa,protokolla vain kehystää tiedon Kuvia Videoa Suoritettava ohjelma HTTP ei tarjoa virheenkorjausta, se olettaa että virheet korjataan ylä- tai alapuolella Protokolla on muotoa pyyntö-vastaus Pyyntö sisältää kaikki vastauksen muodostamiseen tarvittavat tiedot ja toiveet Asiakas toivoo, että palvelin vastaa pyyntöön 12

Siirtoprotokolla Kuinka HTTP-protokollan viestit siirretään asiakkaan ja palvelimen välillä? Vastaus: HTTP käyttää viestien siirtoon TCP-protokollaa 13

TCP:n tarjoama palvelu TCP toteuttaa kaksisuuntaisen tavuvirran asiakkaan ja palvelimen välillä Palvelin odottaa yhteyksiä; asiakas avaa yhteyden Kumpikin kirjoittaa ja lukee tavuja virrasta Asiakas 80 GET /~jsuvileh/jotime/esimerkki.html HTTP/1.x 200 OK Internet Palvelin Palvelut on numeroitu: HTTP-palvelinohjelma odottaa yhteyksiä porttinumerossa 80 Telnet-ohjelmalla TCP:tä voi käyttää käsin 14

Protokollapino ja rajapinnat Miten TCP siirtää tavuvirran asiakkaan ja palvelimen välillä? Vastaus: TCP jakaa tavuvirran lohkoihin ja lähettää lohkot IP-paketeissa Protokollat muodostavat pinon, jossa kukin käyttää alemman kerroksen palveluja HTTP kayttää TCP:tä, TCP käyttää IP:tä Kerrosten välillä on rajapinta Jokainen kerros huolehtii omasta leiviskästään Kerros voidaan vaihtaa ilman että TCP Socket API ohjelmointirajapinta sovelluksia varten 15

Pinon pohja Protokollapinon alimmaisena on asioita, joita opitaan fysiikantunneilla Niihin ei kauheasti mennä tällä kurssilla 16

TCP:n toteutus Asiakas IP-paketteja Palvelin kolmen paketin kättely SYN ACK data SYN- ACK kaksisuuntainen tavuvirta paloiteltuna pakettehin data data Internet 17

IP:n tarjoama palvelu IP siirtää tietopaketteja kahden Internettiin yhdistetyn koneen (host) välillä Paketin koko yleensä alle 1500 tavua Kullakin koneella on IP-osoite Esim. 130.233.194.61 (IPv4) tai 2001:0db8:85a3:0000:0000:8a2e:0370:7334 (IPv6) Periaate: Jokaisella koneella on oma IPosoite ja mikä tahansa kone voi lähettää paketteja mille tahansa koneelle Erillinen DNS-hakemistopalvelu muuttaa nimiä (www.tkk.fi) osoitteiksi 18

Paketit verkossa Esimerkin paketit (Wireshark): 19

Asiakaskone löytää lähimmän reitittimen ja saa oman IPosoitteen automaattisesti DHCP-protokollalla IP-reititys Reitittimet kuljettavat IP-paketteja vastaanottajan IP-osoitteeseen 130.233.194.61 Internet 130.233.224.249 Kunkin koneen tarvitsee tietää vain oma lähin reititin Luottamus muihin reitittimiin saa järjestelmän toimimaan. Reitittimien pitää tietää millä puolella mikin verkon osa on 20

Linkkikerroksen palvelu Miten asiakas- ja palvelinkone siirtävät IPpaketin lähimmälle reitittimelle? Miten reititin siirtää tiedon seuraavalle reitittimelle? Miten tavut koneen muistista lähetetään fyysisenä signaalina? Vastaus: Linkkikerros toteuttaa IP-pakettien siirron fyysisen linkin yli Langaton lähiverkko IEEE 802.11 ADSL Kytketty Ethernet IEEE 802.3 21

Linkkikerroksen toteutus Linkkikerros siirtää IP-paketteja fyysisen siirtotien kuten radioyhteyden, kuparikaapelin tai kuidun yli Kone tai reititin liittyy linkkiin verkkokortilla, jolla on MAC-osoite IP-paketit kapsuloidaan kehyksiin Kehysten bitit koodataan fyysiseksi signaaliksi Linkkikerroksen toteutuksia: Ethernet, WLAN,GPRS DSL, kaapelimodeemi MPLS, ATM 22

Verkko Linkkikerros muodostaa yhteyksiä kahden pisteen välille Kun pisteet ovat yhteydessä yli kahteen muuhun pisteeseen, syntyy verkko, kuten esimerkiksi Internet Internetissä IP-protokolla huolehtii siitä, että yhteydet yhdistyvät verkoksi 23

KUVA 24

Selaimelta palvelimelle: HTTP GET /jsuvileh/jotime/esimerkki.html HTTP/1.1 Host: www.cse.tkk.fi User-Agent: Mozilla/5.0 (Windows; U; Windows NT 6.1; en-us; rv:1.9.1.7) Gecko/20091221 Firefox/3.5.7 Accept: text/html,application/xhtml+xml,application/xml;q=0.9,*/*;q=0.8 Accept-Language: en-us,en;q=0.5 Accept-Encoding: gzip,deflate Accept-Charset: ISO-8859-1,utf-8;q=0.7,*;q=0.7 Keep-Alive: 300 Connection: keep-alive Palvelimelta selaimelle: HTTP/1.x 200 OK Date: Thu, 21 Jan 2010 12:57:12 GMT Server: Apache/1.3.41 (Unix) PHP/4.4.7 DAV/1.0.3 mod_ssl/2.8.31 OpenSSL/0.9.8j Etag: "2f80a6-1d9-4b585a30"Accept-Ranges: bytes Keep-Alive: timeout=15, max=100 Connection: Keep-Alive Content-Type: text/html <!DOCTYPE html PUBLIC '-//W3C//DTD XHTML 1.1//EN' 'http://www.w3.org/tr/xhtml11/dtd/xhtml11.dtd'> <html xmlns='http://www.w3.org/1999/xhtml' xml:lang='fi'> <head> <title>esimerkki</title> </head> <body> <!-- Tämä on kommentti, se ei näy tekstissä --> <h1>otsikko</h1> <p>tämä on erittäin yksinkertainen webbisivu.</p> <div><img src="http://www.aalto.fi/style_aaltofi/img/aalto-logo-1-fi.gif" alt="aalto-yliopiston logo"/></div> </body> </html> 25

Asiakas (käyttäjä, työasema ja selainohjelma) Nettiselailu Internet www.cse.tkk.fi www.aalto.fi sivu http://www.cse.tkk.fi/~jsuvileh/ jotime/esimerkki.html kuva http://www.aalto.fi/style_aaltofi/ img/aalto-logo-3-fi.gif 26

Selaimelta palvelimelle: GET /style_aaltofi/img/aalto-logo-1-fi.gif HTTP/1.1 Host: www.aalto.fi HTTP User-Agent:Mozilla/5.0 (Windows; U; Windows NT 6.1; en-us; rv:1.9.1.7) Gecko/20091221 Firefox/3.5.7 Accept:image/png,image/*;q=0.8,*/*;q=0.5 Accept-Language:en-us,en;q=0.5 Accept-Encoding: gzip,deflate Accept-Charset:ISO-8859-1,utf-8;q=0.7,*;q=0.7 Keep-Alive:300 Connection:keep-alive Referer http://www.cse.tkk.fi/~jsuvileh/jotime/esimerkki.html HTTP-pyyntö HTTP-pyynnön otsakkeet HTTP/1.0 200 OK Date:Thu, 21 Jan 2010 13:40:19 GMT Server:Apache/2.2.3 (Red Hat) Last-Modified:Mon, 21 Dec 2009 15:04:52 GMT Etag:"3bb63-832-47b3e6951cd00 Accept-Ranges:bytes Content-Length:2098 Cache-Control:max-age=3600 Expires:Thu, 21 Jan 2010 14:40:19 GMT Content-Type:image/gif HTTP-vastaus HTTP-vastauksen otsakkeet GIF89a..K...@@@...@...000... ```...pppppp...`...o.p...0.. x...p...e...!...,...k...'.di.h..l..p,.tm.x.....ph,...r..d.p.`.ed"..v..z.`.e3...4f....%x...>..u6.i..g.ld.y. 2.x#...H...".x.=...t..8 {.{.6...X@.z.."...w...w.<.../...x.4...n>.z..w#...,...$...}2...>.{.1...e...0..)t.`.4.2$..(h...jP.@.hw.4.6P...x...X..@... 4..1x3'...\z0P.'M...p.'P.JI.h.+...D...[.8.&..D.h.]...Ir...(@...H...g0t Q...."...AU.d^)E.p...%..J{..^...0p... \.;^...xq...y)..w.%-.,...!..:...dmvf.&...p...m...y 9.{...P+...@...;.F.1I.p.b..6.f...P.4...p...s.}.Rq.Q..m...>..^*^.p.y.i`..dt.d$..@.B.G.}...}4.SN.TV@{?...d.e.LQ..!..y...:R..\0~ $.\...{...(.'...5.R.:...F%...8/...2...zS.D.9..F..xp.L..LX@my,v.u#d..:]VZCu`. 1..e...r.x...7...*..*+...H..y.}...K2:.8!K...Z...X...f.GL(\...V\...6T. Data(GIF) D".P...Y...^...JW...W.N..#J.8B...#..G..u...0...E...Y.c?b.@26.G.}...U..}u.P.&.(..l.&...1T...8V../.Y&,4 }1..(.Q1..P..5..*.B= b%...\[.y...g,1...1./...d.)u.0...j.tq7...jq&8...h;q...%]..._.i..0.z..{.=.c.(xs...w.....b.~...d*.p.>...sv...c 4..5..D...c...X..w.;K(...[)...T"....x...>...By...0.....o..y..y*...~6...>.a...A...@#..,.J..F0.X...E...`. 27

Binääridataa Formaatti on tiedon tallennuksen vastine protokollalle: sääntö siitä, miten tieto tallennetaan ja luetaan. Aalto-yliopiston logo on piirretty kuva (ei valokuva) joten se kannattaa tallentaa GIF tai PNG-formaatissa. Graphics Interchange Format eli GIF on binääriformaatti 28

Tunniste Kuvan koko ja taustaväri Käytetyt värit Kuvan alun sijainti Varsinainen kuvadata (pakattuna) Logossa on paljon valkoista ja isoja samanvärisiä alueita, joten se pakkautuu hyvin. 451x75 = 33 825 pikseliä Tiedostossa on 2098 tavua 29

Äärellinen tarkkuus Multimedia voidaan tallettaa tietokoneeseen vain äärellisellä tarkkuudella. Tietoa talletettaessa käytetään usein hyväksi tietoa ihmisen aisteista 30

Scalable Vector Graphics <?xml version="1.0" standalone="no"?> <!DOCTYPE svg PUBLIC "-//W3C//DTD SVG 1.1//EN" "http://www.w3.org/graphics/svg/1.1/dtd/ svg11.dtd"> <svg width="100%" height="100%" version="1.1" xmlns="http://www.w3.org/2000/svg"> <rect width="300" height="100" style="fill:rgb(0,0,255);stroke-width:1; stroke:rgb(0,0,0)"/> </svg> Tallennetaan vain tieto muodosta, ei yksittäisiä pikseleitä Tuki vajavaista (esim. PowerPoint, vanhat IEselaimet) SVG on XML-pohjainen formaatti, kuten XHTML 31

INTERNET-PROTOKOLLAPINO 32

TCP/IP-protokollapino Sovelluskerros Middleware: HTTP, SSL, XML... Siirtokerros: TCP, UDP,... Verkkokerros: IPv4, IPv6 Linkkikerros: Ethernet, MPSL, WLAN, GPRS... Asiakas/palvelinsovellukset ja monenväliset palveluarkkitehtuurit Tiedonsiirto päästä päähän, Internetin yli (end to end) Tiedonsiirto yhden linkin yli 33

Nimiavaruudet Sovelluskerros Middleware: HTTP, SSL, XML... Siirtokerros: TCP, UDP,... Verkkokerros: IPv4, IPv6 Linkkikerros: Ethernet, MPSL, WLAN, GPRS... Sähköpostiosoite, URL, DNS-nimi, jne. IP-osoite ja porttinumero IP-osoite MAC-osoite 34

Viestien muoto Sovelluskerros Middleware: HTTP, SSL, XML... Pyynnöt ja vastaukset Siirtokerros: TCP, UDP,... Yhteys Verkkokerros: IPv4, IPv6 Linkkikerros: Ethernet, MPSL, WLAN, GPRS... Paketit Kehykset 35

Toteutus ja rajapinnat Sovelluskerros Middleware: HTTP, SSL, XML... Socket API Siirotokerros: TCP, UDP,... Verkkokerros: IPv4, IPv6 Laiteajurirajapinta Linkkikerros: Ethernet, MPSL, WLAN, GPRS... Tyypillinen toteutus: Prosesseina käyttäjätilassa Käyttöjärjestelmän ytimessä Verkkokortin firmware ja rauta 36

Tiimalasimalli Sovelluskerros Middleware: HTTP, SSL, XML... Siirtokerros: TCP, UDP,... IPv4, IPv6 Socket API Laiteajurirajapinta Linkkikerros: Ethernet, MPSL, WLAN, GPRS... Rajapinnat tekevät uusien sovellusten ja linkkityyppien lisäämisen helpoksi Alun perin vain yksi verkkokerroksen protokolla ja kaksi siirtokerroksen protokollaa 37

Lähitulevaisuudessa sovelluskerrosta siirto- ja verkkokerrosta Institut Eurecomin mainos vierailevina tähtinä linkkikerrosta tietoturvaa televerkko, GSM, UMTS ja miljoona muuta lyhennettä 38