Acelerando PrestaShop: Mi solución serverless para Critical CSS

Acelerando PrestaShop: Mi solución serverless para Critical CSS

Jorge Gómez López • 3 de enero de 2026

wpo prestashop

Las tiendas online con PrestaShop no tienen por qué ser lentas, incluso cuando son complejas.

En este caso real implementé una solución en forma de módulo personalizado para conseguir una velocidad de carga competitiva. Identifiqué la lentitud del sitio como uno de los primeros pasos obligatorios para el SEO, ya que era uno de los impedimentos principales a la hora de que las estrategias de posicionamiento funcionasen.

Después de hacer la primera auditoría, concluí que lo más urgente era mejorar esa lentitud: la web tardaba más de 6 segundos en cargar. El sitio necesitaba una actualización y reestructuración profundas, pero era necesario actuar rápido sobre este factor crítico.

Gráfico de rendimiento de la web para móviles de Google Search Console
Mejora drástica de velocidad de carga en un sitio PrestaShop viejo.

Actuar rápido y directo al grano: las campañas de Ads

El problema no era solo orgánico. El cliente invertía en Google Ads, y una página de destino lenta penaliza el Nivel de Calidad (Quality Score). Esto se traduce en clics más caros y menos conversiones. No queremos que el usuario se sienta incómodo nada más llegar simplemente por tener que esperar. O peor, que ni siquiera espere: clic en el anuncio y adiós, a otro sitio.

El diagnóstico técnico apuntaba a un culpable claro: el uso de constructores visuales (como Elementor o Creative Elements) sobre una plantilla ya de por sí pesada. Esto generaba megas de CSS no utilizado que el navegador tenía que procesar antes de mostrar nada al usuario.

El problema de un sitio que aún no puede actualizarse

Lo ideal en estos casos es refactorizar la plantilla o actualizar el CMS. Pero en el mundo real, los clientes no siempre pueden detener su negocio durante unos meses para un rediseño completo.

Necesitábamos una solución que funcionara cuanto antes, sobre la infraestructura actual, sin romper el diseño visual del maquetador pero eliminando su lastre de rendimiento.

Una solución a medida sin ser intrusiva

Probamos módulos de caché comerciales, pero fallaban o rompían la maquetación. Decidí crear una solución de ingeniería a medida: Externalizar la generación del CSS Crítico a la nube.

Diseñé una arquitectura híbrida que conecta el PrestaShop con un microservicio en Google Cloud, externalizando el proceso a una arquitectura Serverless en Google Cloud Run.

1. El Módulo (El Cerebro en PrestaShop)

Desarrollé un módulo que actúa como orquestador dentro de la tienda:

2. La Nube (Google Cloud Run + Docker)

Para no sobrecargar el servidor del cliente, la "fuerza bruta" se hace fuera:

Desafíos técnicos: Limpieza y Seguridad

El código devuelto por herramientas automáticas a veces es sucio. Detectamos y corregimos errores típicos de sintaxis en los archivos CSS de la plantilla, e implementé una capa de limpieza agresiva con Regex en el módulo para eliminar caracteres nulos o residuos que pudieran romper el HTML de PrestaShop.

Además, la seguridad es clave. La API en la nube está protegida para que solo el módulo autorizado pueda solicitar la generación de estilos, evitando abusos de infraestructura.

Mejorando la receta: estandarizar, proteger, escalar

Este desarrollo no se ha quedado estático. Para garantizar la mantenibilidad y la seguridad, he aplicado mejoras continuas al flujo de trabajo:

Los Resultados

Tras implementar esta arquitectura, los números hablaron por sí solos:

Cómo optimizar PrestaShop para ser más rápido

El WPO moderno va más allá de instalar plugins de caché. Requiere arquitectura. Si tu PrestaShop es complejo y usas page builders, la solución no suele estar dentro de PrestaShop, sino en cómo entregas los recursos.

Este caso demuestra que con la ingeniería adecuada (Serverless + Docker + Desarrollo a medida), se puede rescatar el rendimiento de una tienda compleja sin necesidad de rehacerla desde cero.

¿Tu e-commerce necesita una auditoría de arquitectura? Hablemos