Nota:
El acceso a esta página requiere autorización. Puede intentar iniciar sesión o cambiar directorios.
El acceso a esta página requiere autorización. Puede intentar cambiar los directorios.
En este tutorial, aprenderás a implementar un sitio web estático generado por Next.js en Azure Static Web Apps. Para obtener más información sobre aspectos específicos de Next.js, consulte el archivo Léame de la plantilla de inicio.
Prerrequisitos
- Una cuenta de Azure con una suscripción activa. Cree una cuenta gratuita.
- Una cuenta de GitHub. Cree una cuenta gratuita.
- Node.js instalado.
1. Configurar una aplicación de Next.js
En lugar de usar la CLI de Next.js para crear la aplicación, puede usar un repositorio de inicio. El repositorio de inicio contiene una aplicación de Next.js existente que admite rutas dinámicas.
Para empezar, cree un repositorio en la cuenta de GitHub desde un repositorio de plantillas.
Vaya a https://github.com/staticwebdev/nextjs-starter/generate.
Asigne al repositorio el nombre nextjs-starter.
A continuación, clone el nuevo repositorio a su máquina. Asegúrese de reemplazar
<YOUR_GITHUB_ACCOUNT_NAME>por el nombre de la cuenta.git clone http://github.com/<YOUR_GITHUB_ACCOUNT_NAME>/nextjs-starterVaya a la aplicación Next.js recién clonada.
cd nextjs-starterInstale las dependencias.
npm installInicie la aplicación Next.js en desarrollo.
npm run devVaya a
http://localhost:3000para abrir la aplicación, donde debería ver el siguiente sitio web abierto en su navegador preferido.
Al seleccionar un marco o biblioteca, verá una página de detalles sobre el elemento seleccionado:
2. Creación de una aplicación estática
En los pasos siguientes se muestra cómo vincular la aplicación a Azure Static Web Apps. Una vez en Azure, puede implementar la aplicación en un entorno de producción.
Vaya a Azure Portal.
Seleccione Crear un recurso.
Busque Static Web Apps.
Seleccione Aplicación web estática.
Selecciona Crear.
En la pestaña Datos básicos, especifique los valores siguientes.
Propiedad Importancia Subscription Nombre de tu suscripción de Azure. Grupo de recursos my-nextjs-group Nombre my-nextjs-app Tipo de plan Gratis Región para la API y los entornos de ensayo de Azure Functions Seleccione la región más cercana a la suya. Fuente GitHub Seleccione Iniciar sesión con GitHub y autentíquese con GitHub, si se le solicita.
Escriba los siguientes valores de GitHub.
Propiedad Importancia Organización Seleccione la organización de GitHub adecuada. Repositorio Seleccione nextjs-starter. Rama Seleccione main (principal). En la sección Detalles de compilación, seleccione Personalizado en Presets de compilación. Agregue los siguientes valores como para la configuración de compilación.
Propiedad Importancia Ubicación de la aplicación Escriba / en el cuadro. Ubicación de api Deje este cuadro vacío. Ubicación de salida Escriba out en el cuadro.
3. Revisar y crear
Seleccione el botón Revisar y crear para comprobar que todos los detalles son correctos.
Seleccione Crear para comenzar la creación de la aplicación web estática de App Service y aprovisionar una instancia de Acciones de GitHub para la implementación.
Cuando finalice la implementación, seleccione Ir al recurso.
En la ventana Información general , seleccione el vínculo URL para abrir la aplicación implementada.
Si el sitio web no se carga inmediatamente, la compilación todavía se está ejecutando. Para comprobar el estado del flujo de trabajo Acciones, vaya al panel Acciones del repositorio:
https://github.com/<YOUR_GITHUB_USERNAME>/nextjs-starter/actions
Una vez completado el flujo de trabajo, puede actualizar el explorador para ver la aplicación web.
Ahora, los cambios realizados en la main rama inician una nueva compilación e implementación del sitio web.
4. Sincronizar cambios
Al crear la aplicación, Azure Static Web Apps creó un archivo de Acciones de GitHub en el repositorio. Para sincronizar con el servidor, descargue la versión más reciente a su repositorio local.
Vuelva al terminal y ejecute el siguiente comando git pull origin main.
Configuración de la representación estática
De forma predeterminada, la aplicación se trata como una aplicación de Next.js representada híbrida, pero para seguir usándola como generador de sitios estáticos, debe actualizar la tarea de implementación.
Abra el repositorio en Visual Studio Code.
Navegue al archivo de GitHub Actions que Azure Static Web Apps agregó a su repositorio en
.github/workflows/azure-static-web-apps-<your site ID>.ymlActualice el trabajo De compilación e implementación para tener una variable de entorno de
IS_STATIC_EXPORTestablecida entrue:- name: Build And Deploy id: swa uses: azure/static-web-apps-deploy@latest with: azure_static_web_apps_api_token: ${{ secrets.AZURE_STATIC_WEB_APPS_TOKEN }} repo_token: ${{ secrets.GITHUB_TOKEN }} # Used for GitHub integrations (i.e. PR comments) action: "upload" app_location: "/" # App source code path api_location: "" # Api source code path - optional output_location: "" # Built app content directory - optional env: # Add environment variables here IS_STATIC_EXPORT: trueConfirme los cambios en Git e insértelos en GitHub.
git commit -am "Configuring static site generation" && git push
Una vez completada la compilación, el sitio se renderizará estáticamente.
Limpieza de recursos
Si no va a seguir usando esta aplicación, puede eliminar la instancia de Azure Static Web Apps mediante los pasos siguientes.
- Abra Azure Portal.
- Busque my-nextjs-group en la barra de búsqueda superior.
- Seleccione el nombre del grupo.
- Seleccione Eliminar.
- Seleccione Sí para confirmar la acción de eliminación.