Arquitectura de inicio
La arquitectura inicial de su infraestructura en la nube de Adobe Commerce admite hasta cuatro entornos, incluido un entorno master
que contiene el código inicial del proyecto, el entorno de ensayo y hasta dos entornos de integración.
Todos los entornos están en contenedores PaaS (Platform as a service). Estos contenedores se implementan dentro de contenedores altamente restringidos en una cuadrícula de servidores. Estos entornos son de solo lectura, y aceptan cambios de código implementado desde ramas insertadas desde el espacio de trabajo local. Cada entorno proporciona una base de datos y un servidor web.
Puede utilizar cualquier metodología de desarrollo y ramificación que desee. Cuando obtenga acceso inicial a su proyecto, cree un entorno staging
a partir del entorno master
. A continuación, cree el entorno integration
ramificando desde staging
.
Arquitectura del entorno de inicio
El diagrama siguiente muestra las relaciones jerárquicas de los entornos de Starter.
Entorno de producción
El entorno de producción proporciona el código fuente para implementar Adobe Commerce en la infraestructura de nube que ejecuta sus tiendas públicas de uno o varios sitios. El entorno de producción utiliza código de la rama master
para configurar y habilitar el servidor web, la base de datos, los servicios configurados y el código de la aplicación.
Dado que el entorno production
es de solo lectura, use el entorno integration
para realizar cambios en el código, implementar en toda la arquitectura desde integration
hasta staging
y, finalmente, en el entorno production
. Ver Implementar tu tienda y lanzamiento del sitio.
El Adobe recomienda realizar todas las pruebas en la rama staging
antes de transferirla a la rama master
, que se implementa en el entorno production
.
Entorno de ensayo
El Adobe recomienda crear una rama llamada staging
desde master
. La rama staging
implementa código en el entorno de ensayo para proporcionar un entorno de preproducción que pruebe código, módulos y extensiones, puertas de enlace de pago, envío, datos de productos y mucho más. Este entorno proporciona la configuración para que todos los servicios coincidan con el entorno de producción, incluidos Fastly, New Relic APM y search.
En las secciones adicionales de esta guía se proporcionan instrucciones para las implementaciones de código finales y la prueba de interacciones a nivel de producción en un entorno de ensayo seguro. Para obtener el mejor rendimiento y las mejores pruebas de características, duplique la base de datos en el entorno de ensayo.
Entorno de integración
Los desarrolladores utilizan el entorno integration
para desarrollar, implementar y probar:
-
código de aplicación Adobe Commerce
-
Custom Code
-
Extensiones
-
Servicios
Casos de uso recomendados:
Los entornos de integración están diseñados para pruebas y desarrollo limitados. Por ejemplo, puede utilizar el entorno de integración para completar las siguientes tareas:
-
Asegúrese de que los cambios en los procesos de integración continua (CI) sean compatibles con la nube
-
Pruebe flujos de trabajo críticos en páginas clave como Inicio, Categoría, Página de detalles del producto (PDP), Cierre de compra y Administración.
Para obtener el mejor rendimiento en el entorno de integración, siga estas prácticas recomendadas:
-
Restringir el tamaño del catálogo
-
Limitar el uso a uno o dos usuarios simultáneos
-
Deshabilite los trabajos cron y ejecute manualmente según sea necesario
Puede tener hasta dos entornos de integración activos. Cree un entorno de integración creando una rama a partir de la rama staging
. Cuando crea un entorno de integración, el nombre del entorno coincide con el nombre de la rama. Un entorno de integración incluye un servidor web y una base de datos. No incluye todos los servicios; por ejemplo, Fastly, CDN y New Relic no están disponibles.
Puede tener un número ilimitado de ramas inactivas para el almacenamiento de código. Para acceder, ver y probar una rama inactiva, debe activarla
Pila de tecnología de producción y ensayo
Los entornos de producción y ensayo incluyen las siguientes tecnologías. Puede modificar y configurar estas tecnologías a través del archivo .magento.app.yaml
.
- Rápidamente para almacenamiento en caché HTTP y CDN
- Nginx servidor web hablando con PHP-FPM, una instancia con varios trabajadores
- Servidor Redis
- Elasticsearch para la búsqueda en el catálogo de Adobe Commerce 2.2 a 2.4.3-p2
- AbraBuscar en el catálogo Adobe Commerce 2.3.7-p3, 2.4.3-p2 y 2.4.4 y posterior
- Filtrado de salidas (cortafuegos de salida)
Servicios
Adobe Commerce en la infraestructura en la nube admite actualmente los siguientes servicios: PHP, MySQL (MariaDB), Elasticsearch (Adobe Commerce 2.2 a 2.4.3-p2), OpenSearch (2.3.7-p3, 2.4.3-p2, 2.4.4 y posterior), Redis y RabbitMQ.
Cada servicio se ejecuta en un contenedor independiente y seguro. Los contenedores se administran juntos en el proyecto. Algunos servicios son estándar, como los siguientes:
-
Enrutador HTTP (administra solicitudes entrantes, pero también almacena en caché y redirige)
-
servidor de aplicaciones PHP
-
Git
-
Secure Shell (SSH)
Versiones de software
Adobe Commerce en la infraestructura en la nube utiliza el sistema operativo Debian GNU/Linux y el servidor web NGINX. No puede actualizar este software, pero puede configurar versiones para lo siguiente:
En los entornos de ensayo y producción, se utiliza Fastly para la CDN y el almacenamiento en caché. La última versión de la extensión CDN de Fastly se instala durante el aprovisionamiento inicial del proyecto. Puede actualizar la extensión para obtener las últimas correcciones y mejoras de errores. Consulte Módulo de CDN de Fastly para el Magento 2. Además, tiene acceso a New Relic para supervisar el rendimiento.
Utilice los siguientes archivos para configurar las versiones de software que desea utilizar en la implementación.
Backup y recuperación ante desastres
Puede crear una copia de seguridad de la base de datos y del sistema de archivos mediante Cloud Console o CLI. Consulte Administración de copias de seguridad.
Preparación para el desarrollo
El siguiente flujo de trabajo resume el proceso para bifurcar el código, desarrollar e implementar la tienda:
-
Configurar el entorno local
-
Clonar la rama
master
a su entorno local -
Crear una rama
staging
desdemaster
-
Crear ramas para desarrollo a partir de
staging
-
Código push para Git que crea e implementa en un entorno para realizar pruebas
Consulte las secciones siguientes para obtener instrucciones detalladas y tutoriales para desarrollar, probar e implementar su tienda:
-
Desarrollo de Docker (entorno de desarrollo local habilitado por Cloud Docker para Commerce)