Déployez votre site Astro sur les pages Cloudflare
Vous pouvez déployer votre projet Astro sur Cloudflare Pages, une plateforme permettant aux développeurs frontaux de collaborer et de déployer des sites web statiques (JAMstack) et SSR.
Ce guide comprend :
- Comment déployer via le Cloudflare Pages Dashboard
- Comment déployer un site en utilisant Wrangler, la CLI de Cloudflare
- Comment déployer un site SSR en utilisant
@astrojs/cloudflare
Pré-requis
Titre de la section Pré-requisPour commencer, vous aurez besoin :
- Un compte Cloudflare. Si vous n’en avez pas encore, vous pouvez créer un compte Cloudflare gratuit au cours de la procédure.
- Le code de votre application poussé sur un dépôt GitHub ou GitLab.
Comment déployer un site avec Git
Titre de la section Comment déployer un site avec Git-
Créez un nouveau projet sur Cloudflare Pages.
-
Poussez votre code dans votre dépôt Git (GitHub, GitLab).
-
Connectez-vous au tableau de bord de Cloudflare et sélectionnez votre compte dans Comptes > Workers et Pages.
-
Sélectionnez Créer une application, naviguez dans l’onglet Pages et cliquez sur Se connecter à Git.
-
Sélectionnez le projet git que vous souhaitez déployer et cliquez sur Commencer la configuration.
-
Utilisez les paramètres de construction suivants :
- Framework preset:
Astro
- Build command:
npm run build
- Build output directory:
dist
- Framework preset:
-
Cliquez sur le bouton Enregistrer et déployer.
Comment déployer un site à l’aide de Wrangler
Titre de la section Comment déployer un site à l’aide de Wrangler- Installez Wrangler CLI.
- Authentifiez Wrangler avec votre compte Cloudflare en utilisant
wrangler login
. - Lancez votre commande de construction.
- Déployez en utilisant
npx wrangler pages deploy dist
.
Une fois vos ressources téléchargées, Wrangler vous donnera une URL de prévisualisation pour inspecter votre site. Lorsque vous vous connectez au tableau de bord de Cloudflare Pages, vous verrez votre nouveau projet.
Activer la prévisualisation localement avec Wrangler
Titre de la section Activer la prévisualisation localement avec WranglerPour que la prévisualisation fonctionne, vous devez installer wrangler
Il est alors possible de mettre à jour le script de prévisualisation pour exécuter wrangler
au lieu de la commande de prévisualisation intégrée à Astro :
Comment déployer un site SSR
Titre de la section Comment déployer un site SSRVous pouvez construire un site Astro SSR pour le déployer sur Cloudflare Pages en utilisant l’adaptateur @astrojs/cloudflare
.
Suivez les étapes ci-dessous pour configurer l’adaptateur. Vous pouvez ensuite déployer en utilisant l’une ou l’autre des approches documentées ci-dessus.
Installation rapide
Titre de la section Installation rapideAjoutez l’adaptateur Cloudflare pour activer SSR dans votre projet Astro avec la commande astro add
suivante. Cela installera l’adaptateur et apportera les changements appropriés à votre fichier astro.config.mjs
en une seule étape.
Installation manuelle
Titre de la section Installation manuelleSi vous préférez installer l’adaptateur manuellement, suivez les deux étapes suivantes :
-
Ajoutez l’adaptateur
@astrojs/cloudflare
aux dépendances de votre projet en utilisant votre gestionnaire de paquets préféré. Si vous utilisez npm ou si vous n’êtes pas sûr, lancez ceci dans le terminal : -
Ajoutez ce qui suit à votre fichier
astro.config.mjs
:
Dépannage
Titre de la section DépannageHydratation côté client
Titre de la section Hydratation côté clientL’hydratation côté client peut échouer à cause du paramètre Auto Minify de Cloudflare. Si vous voyez Hydration completed but contains mismatches
dans la console, assurez-vous de désactiver Auto Minify dans les paramètres de Cloudflare.
API d’exécution Node.js
Titre de la section API d’exécution Node.jsSi vous construisez un projet qui utilise le rendu à la demande avec l’adaptateur Cloudflare SSR et que le serveur ne parvient pas à s’afficher avec un message d’erreur tel que “Si vous construisez un projet qui utilise le rendu à la demande avec l’adaptateur Cloudflare SSR et que le serveur ne parvient pas à s’afficher avec un message d’erreur tel que [Error] Could not resolve "XXXX. The package "XXXX" wasn't found on the file system but is built into node.
:
-
Cela signifie qu’un paquetage ou une importation que vous utilisez dans l’environnement côté serveur n’est pas compatible avec les Cloudflare Workers runtime APIs.
-
Si vous importez directement une API d’exécution Node.js, veuillez consulter la documentation Astro sur la compatibilité Node.js de Cloudflare pour savoir comment résoudre ce problème.
-
Si vous importez un paquet qui importe une API d’exécution Node.js, vérifiez avec l’auteur du paquet s’il supporte la syntaxe d’importation
node:*
. Si ce n’est pas le cas, vous devrez peut-être trouver un autre paquetage ou utiliser un autre adaptateur.