Aller au contenu

Îlots de serveur

Les îlots de serveurs vous permettent de rendre à la demande des « îles » dynamiques ou personnalisées individuellement, sans sacrifier les performances du reste de la page.

Cela signifie que votre visiteur verra les parties les plus importantes de votre page plus tôt, et permet à votre contenu principal d’être mis en cache de manière plus intensive, ce qui permet d’obtenir des performances plus rapides.

Un îlot de serveur est un composant Astro normal rendu par le serveur, qui est chargé de différer le rendu jusqu’à ce que son contenu soit disponible.

Votre page sera rendue immédiatement avec tout contenu de secours. Ensuite, le contenu du composant est récupéré sur le client et affiché lorsqu’il est disponible.

Avec un adaptateur installé pour effectuer le rendu différé, ajoutez la directive server:defer à n’importe quel composant de votre page pour le transformer en sa propre île :

src/pages/index.astro
---
import Avatar from '../components/Avatar.astro';
---
<Avatar server:defer />

Ces composants peuvent faire tout ce que vous feriez normalement dans une page rendue à la demande à l’aide d’un adaptateur, comme récupérer du contenu et accéder aux cookies :

src/components/Avatar.astro
---
import { getUserAvatar } from '../sessions';
const userSession = Astro.cookies.get('session');
const avatarURL = await getUserAvatar(userSession);
---
<img alt="Avatar de l'utilisateur" src={avatarURL} />

Contenu de secours de l’île du serveur

Titre de la section Contenu de secours de l’île du serveur

Lorsque vous utilisez l’attribut server:defer sur un composant pour retarder son rendu, vous pouvez « insérer » un contenu de chargement par défaut en utilisant le slot nommé "fallback" inclus.

Votre contenu de repli sera rendu avec le reste de la page initialement au chargement de la page et sera remplacé par le contenu de votre composant lorsqu’il sera disponible.

Pour ajouter un contenu de repli, ajoutez slot="fallback" sur un enfant (d’autres composants ou éléments HTML) transmis à votre composant de l’île du serveur :

---
import Avatar from '../components/Avatar.astro';
import GenericAvatar from '../components/GenericAvatar.astro';
---
<Avatar server:defer>
<GenericAvatar slot="fallback" />
</Avatar>

Ce contenu de secours peut-être, par exemple, un avatar générique au lieu de celui de l’utilisateur :

  • Un avatar générique au lieu de celui de l’utilisateur.
  • Une interface utilisateur remplaçable, telle que des messages personnalisés.
  • Des indicateurs de chargement tels que des spinners.

L’implémentation des îlots du serveur se fait principalement au moment de la construction, où le contenu des composants est remplacé par un petit script.

Chacun des îlots marqués avec server:defer est divisé en sa propre route spéciale que le script récupère au moment de l’exécution. Quand Astro construit votre site, il omet le composant et injecte un script à sa place, ainsi que tout contenu que vous avez marqué avec slot="fallback".

Lorsque la page se charge dans le navigateur, ces composants sont demandés à un point de terminaison spécial qui les rend et renvoie le code HTML. Cela signifie que les utilisateurs verront instantanément les parties les plus importantes de la page. Le contenu de repli sera visible pendant un court laps de temps avant que les îlots dynamiques ne soient chargés.

Chaque îlot est chargé indépendamment des autres. Cela signifie qu’un îlot plus lent ne retardera pas la disponibilité du reste de votre contenu personnalisé.

Ce modèle de rendu a été conçu pour être portable. Il ne dépend d’aucune infrastructure de serveur et fonctionnera donc avec n’importe quel hôte, qu’il s’agisse d’un serveur Node.js dans un conteneur Docker ou du fournisseur sans serveur de votre choix.

Les données pour les îlots de serveurs sont récupérées via une requête GET, en passant les props sous forme de chaîne chiffrée dans la requête URL. Cela permet de mettre en cache les données avec l’en-tête HTTP Cache-Control en utilisant des directives Cache-Control standard.

Cependant, le navigateur limite les URL à une longueur maximale de 2048 octets pour des raisons pratiques et pour éviter de causer des problèmes de déni de service. Si votre chaîne de requête fait dépasser cette limite à votre URL, Astro enverra plutôt une requête POST qui contient toutes les props dans le corps.

Les requêtes POST ne sont pas mises en cache par les navigateurs, car elles sont utilisées pour soumettre des données, et pourraient causer des problèmes d’intégrité ou de sécurité des données. Par conséquent, toute logique de mise en cache existante dans votre projet sera cassée. Dans la mesure du possible, ne transmettez que les props nécessaires à vos îlots de serveurs et évitez d’envoyer des objets de données et des tableaux entiers pour garder votre requête petite.

Accéder à l’URL de la page dans un îlot de serveurs

Titre de la section Accéder à l’URL de la page dans un îlot de serveurs

Dans la plupart des cas, votre composant d’îlot serveur peut obtenir des informations sur la page qui le rend en passant des props comme dans les composants normaux.

Cependant, les îlots de serveurs fonctionnent dans leur propre contexte isolé en dehors de la requête de la page. Astro.url et Astro.request.url dans un composant d’îlot serveur renvoient tous deux une URL qui ressemble à /_server-islands/Avatar au lieu de l’URL de la page courante dans le navigateur. De plus, si vous effectuez un pré-rendu de la page, vous n’aurez pas accès à des informations telles que les paramètres de la requête à passer en tant que props.

Pour accéder aux informations de l’URL de la page, vous pouvez vérifier l’en-tête Referer, qui contiendra l’adresse de la page qui charge l’île dans le navigateur :

---
const referer = Astro.request.headers.get('Referer');
const url = new URL(referer);
const productId = url.searchParams.get('product');
---

Réutilisation de la clé de chiffrement

Titre de la section Réutilisation de la clé de chiffrement

Astro utilise la cryptographie pour hacher les éléments transmis aux îles du serveur afin d’éviter toute fuite accidentelle de secrets. Les props sont hachées à l’aide d’une clé générée lors de la construction.

Pour la plupart des hôtes, cela se passe de manière transparente et vous n’avez rien à faire en tant que développeur. Si vous utilisez des déploiements continus dans un environnement tel que Kubernetes, vous pouvez rencontrer des problèmes lorsque le frontend et le backend sont temporairement désynchronisés et que les clés ne correspondent pas.

Pour résoudre ce problème, vous pouvez créer une clé avec l’Astro CLI et la réutiliser pour tous vos déploiements. Cela permet de s’assurer que le frontend de chaque utilisateur parle à un backend qui a la bonne clé.

Générez une clé en utilisant astro create-key :

Fenêtre du terminal
astro create-key

Cela créera une clé que vous pourrez définir comme variable d’environnement ASTRO_KEY là où votre environnement d’hébergement le requiert, comme dans un fichier .env :

.env
ASTRO_KEY=zyM5c0qec+1Sgi4K+AejFX9ufbig7/7wIZjxOjti9Po=
Contribuer

Comment pouvons-nous vous aider ?

Créer une issue GitHub

Le moyen le plus rapide d'alerter notre équipe d'un problème.

Communauté