Certains outils de test de vitesse de bande passante peuvent recommander aux sites de paralléliser les téléchargements sur noms d'hôtes pour servir efficacement le contenu Web aux navigateurs Web. Cette recommandation se produit généralement sur les sites qui utilisent le protocole HTTP/1.1 et se produit lorsque les navigateurs Web limitent le nombre de connexions simultanées à un domaine.
Les sites Web qui ont de nombreux HTTP les demandes de contenu statique (tels que des images, CSS fichiers et JavaScript) rencontrent un avertissement Parallelize Downloads Across Hostnames. Pour contourner cette limitation, configurez le partage de domaine ou utilisez un réseau de diffusion de contenu (CDN).
Le protocole HTTP/2 est devenu le standard principal, rendant obsolète le besoin de téléchargements parallélisés. La plupart des hébergeurs Web utilisent désormais HTTP/2 par défaut et mettent à disposition un CDN gratuit. Étant donné que HTTP/2 est désormais la préférence de Google, envisagez de mettre à jour votre site et votre hébergement en HTTPS.
Pourquoi paralléliser les téléchargements entre les noms d'hôtes?
Les navigateurs Web ne peuvent ouvrir qu'un nombre limité de connexions simultanées par nom d'hôte pour les sites Web qui utilisent le protocole HTTP/1.1. Cette limite peut aller jusqu'à six connexions.
Lorsque davantage de ressources doivent être téléchargées, les ressources supplémentaires doivent attendre dans une file d'attente jusqu'à ce qu'une connexion soit disponible. Les ressources de la file d'attente sont bloquées et la réduction de ce temps de blocage entraîne des temps de chargement de page plus rapides.
Par exemple, si une page Web contient 12 images et que le nombre de connexions autorisées par le navigateur Web est de six, alors six images doivent attendre dans le backlog. Les images du backlog y restent jusqu'à la fin du téléchargement des six premières images.
Si une image telle qu'une icône ou un logo est utilisée plusieurs fois, utilisez un Sprite CSS pour ces images répétées afin de réduire les demandes de ressources.
Qu'est-ce que l'avertissement de parallélisation des téléchargements entre les noms d'hôte?
L'avertissement de parallélisation des téléchargements entre les noms d'hôtes est une règle utilisée dans certains vérificateurs de performances de sites Web. L'avertissement indique que ce navigateur Web n'a pas pu ouvrir le nombre de connexions nécessaires pour télécharger simultanément toutes les ressources du site Web.
Pour les sites Web qui utilisent le protocole HTTP/1.1, le moyen de contourner ce besoin de connexions plus ouvertes est de minimiser les requêtes HTTP, configurez un CDN ou implémentez le partage de domaine.
Pour les sites Web qui utilisent le protocole HTTP/2, plusieurs ressources peuvent se charger en parallèle sur une seule connexion; c'est ce qu'on appelle le multiplexage. Le multiplexage rend le partage de domaine inutile avec HTTP/2. Environ 77 % des navigateurs Web prennent en charge HTTP/2 et ne devraient pas rencontrer de problème avec la parallélisation des téléchargements.
Si votre fournisseur d'hébergement Web prend en charge HTTP/2, vous pouvez ignorer l'avertissement de parallélisation des téléchargements entre les noms d'hôtes. Avec HTTP/2, plusieurs ressources peuvent être téléchargées en parallèle sur une seule connexion.
Qu'est-ce que le partage de domaine?
Le sharding de domaine est une méthode d'optimisation des performances pour les connexions HTTP/1.1 et est utilisé sur les sites Web avec un grand volume de requêtes HTTP. Dans le sharding de domaine, les actifs de contenu Web sont répartis entre plusieurs sous-domaines. Lorsque les actifs sont répartis de cette manière, le nombre de demandes simultanées pouvant être traitées augmente.
Dans le sharding de domaine, le contenu est téléchargé sur des sous-domaines sans cookies. Les utilisateurs n'interagissent pas avec le contenu statique tel que les images, les fichiers JavaScript et CSS, ce contenu n'a donc pas besoin d'être associé à des cookies.
Lorsque les sous-domaines ne servent pas de cookies, la taille des demandes effectuées pour une page et la latence des demandes diminuent, et les pages Web se chargent plus rapidement. Les exemples de contenu qui bénéficient du partage de domaine incluent les pages dont le contenu est rarement mis en cache, comme une page de vignettes ou une archive d'images.
Dans Drupal, les modules ajoutent des fichiers CSS et JavaScript qui peuvent ralentir les performances. Aller à Configuration du site > Performance et optimiser CSS et JavaScript.
Pour profiter des avantages du partage de domaine sur les connexions HTTP/1.1, suivez ces conseils:
- Servez des ressources des mêmes sous-domaines pour mettre efficacement en cache les fichiers.
- Répartir les ressources uniformément entre les sous-domaines.
- Achetez des certificats SSL pour les sous-domaines.
Sur les connexions HTTP/2, le partage de domaine réduit les performances car il existe des recherches DNS supplémentaires. Ces recherches DNS augmentent le temps de résolution et ne mettent pas en cache les fichiers. Le partage de domaine ajoute également du temps à chaque nouvelle connexion. Voici d'autres inconvénients du partage de domaine sur les connexions HTTP/2:
- La distribution des ressources qui se chargent à partir de CSS est difficile à distribuer entre les hôtes partitionnés.
- Charge plus élevée sur le serveur en raison du nombre accru de connexions simultanées.
- Le déplacement de contenu statique vers un sous-domaine peut casser le code.
- Le navigateur Web peut ne pas autoriser l'accès à un autre nom d'hôte.
- Les routeurs peuvent ne pas être en mesure de classer un grand nombre de demandes fragmentées ou peuvent considérer les demandes comme une attaque par déni de service.
Comment paralléliser les téléchargements entre les noms d'hôtes
Lorsque vous recevez l'avertissement de parallélisation des téléchargements entre les noms d'hôtes, vous devez augmenter la parallélisation des téléchargements en répartissant les demandes entre plusieurs noms d'hôtes. Pour distribuer les demandes, créez des sous-domaines pour les différents types d'actifs Web utilisés sur le site, puis spécifiez le domaine racine comme le seul domaine qui utilise des cookies. Les sous-domaines n'utilisent pas de cookies.
Ces sous-domaines ajoutent de nouvelles sources de connexions que le navigateur peut établir et permettent de télécharger plus de ressources en même temps. Lorsque les ressources sont réparties entre les sous-domaines, le navigateur Web passe moins de temps à bloquer le contenu Web et les pages Web se chargent plus rapidement.
Pour les sites Web qui utilisent HTTP/2 et HTTP/1.1, le moyen le plus simple de paralléliser les téléchargements entre les noms d'hôtes consiste à utiliser plusieurs sous-domaines via un CDN. Pour les sites Web utilisant HTTP/1.1 et WordPress, configurez des sous-domaines et modifiez le fichier WordPress functions.php.
Configurer des sous-domaines
Pour répartir les ressources entre les sous-domaines, créez au moins un et jusqu'à quatre sous-domaines; un ou deux sous-domaines sont recommandés. Le moyen le plus courant de créer des sous-domaines consiste à utiliser cPanel, proposé par la plupart des services d'hébergement Web.
Voici des exemples de sous-domaines:
- media1.mondomaine.com
- media2.mondomaine.com
- media3.mondomaine.com
- media4.mondomaine.com
De plus, les sous-domaines et les noms d'hôtes doivent avoir la même structure et le même chemin. Par exemple, si le chemin de l'image sur l'hôte est www.mydomain.com/wp-content/uploads/, le chemin de l'image sur les sous-domaines doit correspondre, par exemple, media1.mydomain.com/wp-content/uploads/.
Configurer un CDN pour paralléliser les téléchargements
Une fois le CDN configuré et les sous-domaines créés, pointez chaque sous-domaine vers le dossier qui contient le contenu statique. De cette façon, le contenu est chargé sur le sous-domaine au lieu du domaine principal.
Pour pointer un sous-domaine, utilisez un éditeur de zone DNS dans cPanel pour créer un nouvel enregistrement CNAME pour chaque sous-domaine. Dans le champ Nom de l'enregistrement, saisissez le sous-domaine, par exemple, media.mydomain.com. Dans le champ CNAME, saisissez le domaine principal, par exemple, www.mondomaine.com.
Une fois les enregistrements CNAME créés et propagés par votre hébergeur, ajoutez les enregistrements CNAME aux paramètres de la zone CDN.
Modifiez le fichier de configuration du site Web dans WordPress pour paralléliser les téléchargements
Après avoir configuré les sous-domaines, ajoutez ce code au fichier functions.php du thème WordPress utilisé pour votre site Web. Remplacez media1.mydomain.com et media2.mydomain.com par vos sous-domaines réels.
fonction parallelize_hostnames($url, $id) {
$hostname = par_get_hostname($url); //appel une fonction supplémentaire
$url = str_replace (parse_url (get_bloginfo('url'), PHP_URL_HOST), $hostname, $url);
renvoie $url ;
}
fonction par_get_hostname($name) {
$sous-domaines = array('media1.mydomain.com','media2.mydomain.com'); // ajoutez vos sous-domaines ici, autant que vous le souhaitez.
$host = abs (crc32(basename($name)) % count($subdomains));
$hostname = $subdomains[$host] ;
renvoie $hostname ;
}
add_filter('wp_get_attachment_url', 'parallelize_hostnames', 10, 2);
Si vous utilisez Jetpack avec WordPress, activez le service Site Accelerator pour mettre vos images sur un CDN géré par WordPress.