Le protocole IP fait partie de la couche Internet
de la suite de protocoles TCP/IP. C'est un des protocoles les plus importants d'Internet
car il permet l'élaboration et le transport des datagrammes IP (les paquets de données),
sans toutefois en assurer la "livraison".
En réalité le protocole IP traite les datagrammes IP indépendamment
les uns des autres en définissant leur représentation, leur routage et leur
expédition.
Le protocole IP détermine le destinataire du message grâce à 3 champs:
- Le champ adresse IP: adresse de la machine
- Le champ masque de sous-réseau: un masque de sous-réseau permet au protocole
IP de déterminer la partie de l'adressse IP qui concerne le réseau
- Le champ passerelle par défaut: Permet au protocole Internet de savoir à
quelle machine remettre le datagramme si jamais la machine de destination n'est pas sur le réseau
local
Les données circulent sur Internet sous forme de datagrammes (on parle aussi de paquets). Les datagrammes
sont des données encapsulées, c'est-à-dire des données auxquelles
on a ajouté des en-têtes correspondant à des informations sur leur transport
(telles que l'adresse IP de destination, ...).
Les données contenues dans les datagrammes sont analysées (et éventuellement
modifiées) par les routeurs permettant leur transit.
Voici ce à quoi ressemble un datagramme:
<--------------------------- 32 bits --------------------------->
Version |
Longueur d'en-tête |
type de service |
Longueur totale |
Identification |
Drapeau |
Décalage fragment |
Durée de vie |
Protocole |
Somme de contrôle en-tête |
Adresse IP source |
Adresse IP destination |
Données |
Voici la signification des différents champs:
- Version: il s'agit de la version du protocole IP que l'on utilise (actuellement on utilise
la version 4 IPv4) afin de vérifier la validité du datagramme. Elle est codée sur 4 bits
- Longueur d'en-tête: il s'agit du nombre de mots de 32 bits sur lesquels sont répartis l'en-tête
- Type de service: il indique la façon de laquelle le datagramme doit être traité
- Longueur totale: il indique la taille totale du datagramme en octets. La taille de ce champ étant de 2 octets, la taille totale du datagramme ne peut dépasser
65536 octets. Utilisé conjointement avec la taille de l'en-tête, ce champ permet de déterminer où sont situées les données
- identification, drapeaux (flags) et déplacement de fragment sont des champs qui permettent la fragmentation des datagrammes, il seront expliqués plus loin
- Durée de vie: (appelée aussi TTL: Time To Live) indique le nombre maximal de routeurs à travers lesquels le datagramme peut passer. Ainsi
ce champ est décrémenté à chaque passage dans un routeur, lorsque celui-ci atteint la valeur
critique de 0, le routeur détruit le datagramme. Cela évite l'encombrement du réseau par les datagrammes perdus
- Protocole: ce champ permet de savoir de quel protocole est issu le datagramme
- ICMP: 1
- IGMP: 2
- TCP: 6
- UDP: 17
- Somme de contrôle de l'en-tête (header checksum): ce champ contient une valeur codée sur 16 bits
qui permet de contrôler l'intégrité de l'en-tête afin de déterminé si celui-ci
n'a pas éteacute; altéré pendant la transmission. Pour ce faire, on considère l'en-tête
comme une suite d'entiers, on fait la somme de ces enteirs en complément à 1, puis on complémente
le résultat à 1, on obtient alors le total de contrôle. Celui-ci est en fait tel que lorsque l'on fait la somme
des champs de l'en-tête (somme de contrôle inclue) donne un nombre avec tous les bits positionnés à 1
- Adresse IP Source: Ce champ représente l'adresse IP de la machine émettrice, il permet au destinataire de répondre
- Adresse IP destination: Adresse IP du destinataire du message
Comme nous l'avons vu précédemment, la taille d'un datagramme maximale
est de 65535 octets. Toutefois cette valeur n'est jamais atteinte car les réseaux
n'ont pas une capacité suffisante pour envoyer de si gros paquets. De plus, les
réseaux sur Internet utilisent différentes technologies, si bien que la taille
maximale d'un datagramme varie suivant le type de réseau.
La taille maximale d'une trame est appelée MTU (Maximum Transfer Unit), elle
entrainera la fragmentation du datagramme si celui-ci a une taille plus importante que le MTU
du réseau
Type de réseau |
MTU (en octets) |
Arpanet |
1000 |
Ethernet |
1500 |
FDDI |
4470 |
La fragmentation d'un datagramme se fait au niveau des routeurs, c'est-à-dire lors
de la transition d'un réseau dont le MTU est important à un réseau dont le MTU
est plus faible. Si le datagramme est trop grand pour passer sur le réseau, le routeur
va le fragmenter, c'est-à-dire le découper en fragments de tailles inférieures
au MTU du réseau et de telle façon que la taille du fragment soit un multiple de 8 octets.
Le routeur va ensuite envoyer ces fragments de manière indépendante et réencapsulé
(il ajoute un en-tête à chaque fragment) de telle façon à tenir compte de la nouvelle
taille du fragment, et en ajoutant des informations afin que la machine de destination puisse réassembler
les fragments dans le bon ordre (rien ne dit que les fragments vont arriver dans le bon ordre étant
donné qu'ils sont acheminés indépendamment les uns des autres...).
Pour tenir compte de la fragmentation, chaque datagramme possède plusieurs champs permettant
leur réassemblage:
- champ déplacement de fragment: champ permettant de connaître la position du début du fragment dans le datagramme initial
- champ identification: numéro attribué à chaque
fragment afin de permettre leur réassemblage dans le bon ordre
- champ longueur total: il est recalculé pour chaque fragments
- champ drapeau: il est composé de trois bits:
- Le premier n'est pas utilisé
- Le second (appelé DF: Don't Fragment) indique si le datagramme peut être fragmenté ou non.
Si jamais un datagramme a ce bit positionné à un et que le routeur ne peut pas l'acheminer sans le fragmenter, alors le datagramme est rejeté
avec un message d'erreur
- Le dernier (appelé MF: More Fragments, en français Fragments à suivre) indique si le datagramme est un fragment de donnée (1).
Si l'indicateur est à zéro, cela indique que le fragment est le dernier (donc que le routeur devrait être en possession de tous les fragments précédents)
ou bien que le datagramme n'a pas fait l'objet d'une fragmentation
Le routage IP fait partie intégrante de la couche IP de la suite TCP/IP. Le routage
consiste à assurer l'acheminement d'un datagramme IP à travers un réseau
en empruntant le chemin le plus court. Ce rôle est assuré par des machines appelées
routeurs, c'est-à-dire des machines reliées (reliant)
au moins deux réseaux.