IPv4 (Internet Protocol version 4) est la première version d'Internet Protocol (IP) à avoir été largement déployée, et qui forme encore en 2025 la base de la majorité des communications surInternet, par rapport à l'IPv6. Elle est décrite dans laRFC 791[1] de, remplaçant laRFC 760[2], définie en.
Chaque interface d'un hôte IPv4 se voit attribuer une ou plusieursadresses IP codées sur 32 bits. Au maximum 4 294 967 296, soit 232 adresses peuvent donc être attribuées simultanément en théorie (en pratique, un certain nombre ne sont pas utilisables).
L'épuisement des adresses IPv4 a conduit au développement d'une nouvelle version d'IP,IPv6, et à latransition d'IPv4 vers IPv6 afin d'adopter cette nouvelle version. Le manque d'adresse IPv4 est dans un premier temps contourné grâce à l'utilisation de techniques de traduction d'adresses (NAT) ainsi que par l'adoption du systèmeCIDR. Le nombre d'adresses IP Version 4 publiques est arrivé officiellement à saturation le.
Une adresse IPv4 est représentée sous la forme de quatre nombres entiers séparés par des points comme193.43.55.67. Chacun des nombres représente unoctet. La plage d'attribution s'étend de 0.0.0.0 à 255.255.255.255, sachant qu'il existe des contraintes empêchant l'utilisation de certaines adresses (réservée, masque, broadcast, etc.)
Longueur de l'en-tête ouIHL (pourInternet Header Length) (4 bits) :
Ce champ indique en binaire sur 4 bits la longueur totale de l'en-tête et cette longueur est donnée, non pas en bit, ni en octet, mais en mots de 32 bits (=4 octets). La longueur donnée correspondrait au nombre de lignes du schéma précédent. La valeur est comprise entre 5 et 15, car il y a 20 octets minimum et on ne peut dépasser 40 octets d'option. La longueur maximale d'un en-tête est donc de 15*4 octets soit 60 octets.
Ce champ permet de distinguer différentes qualités de service différenciant la manière dont les paquets sont traités. Composé de 3 bits de priorité (donc 8 niveaux) et trois indicateurs permettant de différencier le débit, le délai ou la fiabilité.
Il se décline au fil des RFC. Au départ (RFC 791[1]) nous avions :
Bits 0-2: Precedence.Bit 3: 0 = Normal Delay, 1 = Low Delay.Bits 4: 0 = Normal Throughput, 1 = High Throughput.Bits 5: 0 = Normal Reliability, 1 = High Reliability.Bit 6-7: Reserved for Future Use.
Longueur totale en octets ouTotal Length (16 bits) :
Nombre total d'octets dudatagramme, en-tête IP comprise. Donc, la valeur maximale est 216−1 octets.
Identification (16 bits) :
Numéro permettant d'identifier les fragments d'un même paquet.
Indicateurs ouFlags (3 bits) :
(Premier bit [bit de poids fort]) actuellement inutilisé.
(Deuxième bit) DF (Don't Fragment) : lorsque ce bit est positionné à 1, il indique que le paquet ne peut pas être fragmenté. Si le routeur ne peut acheminer ce paquet (taille du paquet supérieure à la MTU), il est alors rejeté.
(Troisième bit) MF (More Fragments) : quand ce bit est positionné à 1, on sait que ce paquet est un fragment de données et que d'autres doivent suivre. Quand il est à 0, soit le fragment est le dernier (et dans ce cas lefragment offset est différent de 0), soit le paquet n'a pas été fragmenté.
Fragment offset (13 bits) :
Position du fragment par rapport au paquet de départ, en nombre de mots de 8 octets. Lorsque la valeur indiquée est 0, il s'agit du premier fragment.
Durée de vie ou TTL (pourTime To Live) (8 bits) :
Initialisé par l'émetteur, ce champ est décrémenté d'une unité généralement à chaque saut de routeur. Quand TTL = 0, le paquet est abandonné et un message ICMP est envoyé à l'émetteur pour information.
Protocole (8 bits) :
Numéro du protocole au-dessus de lacouche réseau : TCP = 6, UDP = 17, ICMP = 1.
Ce champ permet d'identifier le protocole utilisé par le niveau supérieur :
Somme de contrôle de l'en-tête ouHeader Checksum (16 bits) :
Complément à un de la somme complémentée à un de tout le contenu de l'en-tête afin de détecter les erreurs de transfert. Si la somme de contrôle est invalide, le paquet est abandonné sansmessage d'erreur.
Champ de taille variable comprise entre 0 et 7 bits. Il permet de combler le champ option afin d'obtenir un en-tête IP multiple de 32 bits. La valeur des bits de bourrage est 0.
Sur une interface déterminée, une trame a une taille maximale, appeléeMaximum Transmission Unit ou MTU. Lorsque la longueur du paquet (datagramme) est supérieure, l'information sera fragmentée. La taille maximum supportée par IPv4 (car codée sur 16 bits) est de 65 535 octets mais les réseaux ne prennent généralement pas en charge de trames de telles longueurs, en général on trouve des MTU de l'ordre de 1 500 octets (Ethernet).
↑« Pv6 : Retour sur l’atelier dédié au développement et à l’avancée de l’IPv6 en France, organisé le 7 décembre 2023 », communiqué de presse, 22 décembre 2023 (lire en ligne).