LaunchFast Logo LaunchFast

Implemente Astro en AWS Amplify: una guía paso a paso

Rishi Raj Jain
Deploy Astro to AWS Amplify

En esta guía, aprenderá cómo implementar un proyecto Astro SSR en AWS Amplify. Pasará por el proceso de configurar un nuevo proyecto Astro, habilitar la representación del lado del servidor mediante el adaptador AWS Amplify y, finalmente, implementarlo en AWS Amplify.

Tabla de contenido

Requisitos previos

Necesitará lo siguiente:

Crea una nueva aplicación Astro

Comencemos creando un nuevo proyecto Astro. Abra su terminal y ejecute el siguiente comando:

npm create astro@latest my-app

npm create astro es la forma recomendada de desarrollar rápidamente un proyecto Astro

Cuando se le solicite, elija:

  • Empty cuando se le pregunta cómo iniciar el nuevo proyecto
  • cuando se le pregunte si planea escribir Typecript
  • Estricto cuando se le pregunta qué tan estricto debe ser Typecript.
  • cuando se le solicita instalar dependencias
  • cuando se le solicita inicializar un repositorio de git

Una vez hecho esto, puede ir al directorio del proyecto e iniciar la aplicación:

cd my-app
npm run dev

La aplicación debería estar ejecutándose en localhost:4321

A continuación, en su primera ventana de terminal, ejecute el siguiente comando para instalar las bibliotecas y paquetes necesarios para crear la aplicación:

npm install dotenv

Las bibliotecas instaladas incluyen:

  • dotenv: una biblioteca para manejar variables de entorno

Introducción al adaptador AWS Amplify para Astro

Antes de implementar su proyecto Astro, necesita instalar el adaptador astro-aws-amplify. Esto se hace fácilmente a través de Astro CLI:

npm install astro-aws-amplify

Las bibliotecas instaladas incluyen:

  • astro-aws-amplify: un adaptador que prepara los sitios web de Astro para su implementación en AWS Amplify

Una vez que el adaptador esté instalado, deberá agregarlo a su archivo astroconfigmjs. Abra el archivo y agregue el siguiente código:

import { defineConfig } from 'astro/config';
import awsAmplify from 'astro-aws-amplify'; 

// https://astro.build/config
export default defineConfig({
  output: "server", 
  adapter: awsAmplify(), 
});

Las adiciones hacen lo siguiente:

  • Importa la exportación predeterminada de astro-aws-amplify
  • Utiliza la importación anterior como “adaptador” de su aplicación Astro
  • Establece salida en servidor para habilitar la salida compatible con la representación del lado del servidor

Luego, cree un amplifyyml en la raíz del repositorio con el siguiente código:

version: 1
frontend:
  phases:
    preBuild:
      commands:
        - npm ci
    build:
      commands:
        - env >> .env
        - npm run build
        - mv node_modules ./.amplify-hosting/compute/default
        - mv .env ./.amplify-hosting/compute/default/.env
  artifacts:
    baseDirectory: .amplify-hosting
    files:
      - '**/*'
  cache:
    paths:
      - node_modules/**/*

El código anterior hace lo siguiente:

  • Utiliza comandos preBuild para instalar las dependencias de tu proyecto Astro
  • Utiliza comandos build para:
    • Almacene todas las variables de entorno en el archivo env en la raíz del proyecto
    • Construye tu aplicación Astro
    • Mueva el directorio node_modules y el archivo env al directorio de cálculo de Amplify

Implementar en AWS Amplify

El código ahora está listo para implementarse en AWS Amplify. Utilice los siguientes pasos para implementarlo:

  • Comience creando un repositorio de GitHub que contenga el código de su aplicación.

  • Luego, navegue hasta el panel de AWS Amplify y haga clic en Comenzar en la sección Alojar su aplicación web

Host your web app in AWS Amplify
  • Selecciona GitHub como fuente de tu repositorio Git.
GitHub as code source in AWS Amplify
  • Vincula el nuevo proyecto al repositorio de GitHub que acabas de crear.
Link Repo in AWS Amplify
  • Asigne un nombre a su proyecto y haga clic en Configuración avanzada
Name the project in AWS Amplify
  • En Configuración avanzada, actualice las Variables de entorno para que coincidan con las de su archivo env local y PORT como 3000. Haga clic en Siguiente para continuar.
Add Environment Variables in AWS Amplify
  • Haga clic en Guardar e implementar para implementar su sitio web.
Deploy to AWS Amplify
  • Obtenga la URL de implementación bajo el título Dominio en la información de compilación exitosa.
Grab Deployment URL in AWS Amplify

Conclusión

¡Hurra! Ahora tiene un proyecto Astro que se implementa automáticamente en AWS Amplify al presionar Git.

Si tiene alguna pregunta o comentario, no dude en comunicarse conmigo en Twitter

Learn More Uso de OpenAI Swarm en Python: una guía paso a paso
Uso de OpenAI Swarm en Python: una guía paso a paso October 18, 2024
Cree un bot de Telegram en el enrutador de aplicaciones Next.js: una guía paso a paso
Cree un bot de Telegram en el enrutador de aplicaciones Next.js: una guía paso a paso July 3, 2024
Inyectar variables de entorno dinámicamente en páginas de Cloudflare
Inyectar variables de entorno dinámicamente en páginas de Cloudflare June 13, 2024