Introduzione Livello Trasporto
afdòkjklsòjf
Indirizzamento
La maggior parte dei sistemi operativi è multiutente e multi-processo:
- Diversi processi client attivi (host locale)
- Diversi processi server attivi (host remoto)
Per stabilire una comunicazione tra i due processi è necessario un metodo per individuare:
- Host locale
- Host remoto
- Processo locale
- Processo remoto
Porta vs IP
- Ad un host è associato un indirizzo IP.
- Ad un processo è associata una porta
Incapsulamento e Decapsulamento
Multiplexing e Demultiplexing
Demultiplexing
Multiplexing
Socket
Le socket sono delle astrazioni create ed utilizzate dai programmi applicativi utilizzate per la comunicazione tra un processo client e un processo server significa comunicare tra due socket create nei due lati di comunicazione.
Una socket é una struttura dati che nella sua forma più semplice è composta da due informazioni un indirizzo IP e un numero di porta.
Numero di Porta
Individuare un Socket
Lato Client
Lato server
Su due processi client diversi comunicano allo stesso processo server vedranno un socket address diverso, con l’indirizzo ip uguale ma numero porta diverso.
kjlkajdfskl
Servizi dei protocolli di trasporto Internet
Protocollo UDP (User Datagram Protocol)
kjsslkdzjf
Servizio senza connessione
- è il mittente che deve preoccuparsi di dividere i pacchetti in dimensioni ottimali per l’invio
- ogni pacchetto è indipendente dagli altri (ordine d’arrivo potrebbe essere diverso rispetto all’ordine d’arrivo)
Rappresentazione FSM
Il comportamento di un protocollo di trasporto può essere rappresentato da un automa a stati finiti (FSM - Finite State Machine).
Struttura dei datagrammi
Checksum
Volgiamo calcolare il checksum di una sequenza di 32 bit la divido a metà ottenendo due sequenze da 16 faccio la somma, il risulato è le checksum. Ora se mando la stringa posso inviare anche la checksum, cosi il ricevente può ricalcolarla per vedere se coincide.
Verso TCP
- Comunicazione tra processi con Indirizzamento mediante numero di porta
- Incapsulamento/decapsulamento (frammenti)
- Multiplexing/demultiplexing
- Trasporto orientato alla connessione
- Controllo di flusso
- Controllo degli errori
- Controllo della congestione
prime tre sono anche dell’udp