Configurar Redis para caché predeterminada y de página
Commerce proporciona opciones de línea de comandos para configurar la página Redis y el almacenamiento en caché predeterminado. Aunque puede configurar el almacenamiento en caché mediante la edición del archivo <Commerce-install-dir>app/etc/env.php, la línea de comandos es el método recomendado, especialmente para las configuraciones iniciales. La línea de comandos proporciona validación para garantizar que la configuración sea sintácticamente correcta.
Requisito previo:
Instale Redis antes de continuar.
Marcos admitidos
-
Caché Zend (2.4.8 y anteriores): back-end heredado de Redis para Commerce 2.4.8 y anteriores:
- Servidor Redis heredado — Utiliza la ruta de clase completa (
Magento\Framework\Cache\Backend\Redis) - Claves de precarga: admite la precarga de claves de caché utilizadas frecuentemente
- Scripts de Lua: Lua para la recolección de basura
- Compresión: admite la compresión de datos
- Servidor Redis heredado — Utiliza la ruta de clase completa (
-
Caché Symfony (2.4.9+): a partir de Commerce 2.4.9, la caché Symfony proporciona una implementación de caché moderna compatible con PSR-6 para Redis con mejoras de rendimiento significativas:
- Canalización automática de Redis: agrupa varias operaciones en solicitudes únicas, lo que reduce la latencia
- PSR-6 TagAwareAdapter: invalidación eficiente de caché basada en etiquetas con operaciones atómicas
- Serialización binaria Igbinary: la serialización binaria reduce el tamaño de entrada de caché en un 45% y mejora la velocidad en un 5-10%
- Conexiones persistentes mejoradas: agrupación de conexiones más estable con mejor manejo de los procesos bifurcados
- Scripts Lua optimizados: ejecución del lado del servidor combinada con canalización para lograr la máxima eficiencia
Configurar el almacenamiento en caché predeterminado de Redis
Ejecute el comando setup:config:set y especifique los parámetros específicos de Redis para el almacenamiento en caché predeterminado.
bin/magento setup:config:set --cache-backend=redis --cache-backend-redis-<parameter>=<value>...
Con los siguientes parámetros:
-
--cache-backend=redishabilita el almacenamiento en caché predeterminado de Redis. Si esta función ya se ha habilitado, omita este parámetro. -
--cache-backend-redis-<parameter>=<value>es una lista de pares de clave y valor que configuran el almacenamiento en caché predeterminado:
cache-backend-redis-server127.0.0.1cache-backend-redis-port6379cache-backend-redis-dbImportante: Si utiliza Redis para más de un tipo de almacenamiento en caché, los números de base de datos deben ser diferentes. Se recomienda asignar el número de base de datos de almacenamiento en caché predeterminado a 0, el número de base de datos de almacenamiento en caché de páginas a 1 y el número de base de datos de almacenamiento de sesión a 2.
0cache-backend-redis-passwordauth, que requiere que los clientes se autentiquen para tener acceso a la base de datos. La contraseña está configurada directamente en el archivo de configuración de Redis: /etc/redis/redis.confcache-backend-redis-use-luaValor predeterminado: mantener en
0. El modo Lua está deshabilitado de forma predeterminada para evitar regresiones de rendimiento conocidas y problemas de pérdida de caché de GraphQL introducidos por la biblioteca Redis integrada (1.17.x) cuando Lua estaba habilitado.0cache-backend-redis-use-lua-on-gcbackend_clean_cache).Valor predeterminado: mantener en
1. Habilitado de forma intencionada para garantizar la limpieza del conjunto de etiquetas atómicas durante la CG. Sin ella, puede producirse una condición de carrera cuando el cron backend_clean_cache se ejecuta al mismo tiempo que una operación de guardado de caché, lo que deja las entradas de caché sin un registro correspondiente en el índice de etiquetas de caché. Esto provoca que la invalidación basada en etiquetas falle de forma silenciosa; por ejemplo, actualizar un precio de producto puede no invalidar la caché del producto y, en su lugar, requerir un vaciado de caché completo.1Modo Lua
Cuando se habilita, el modo Lua agrupa varias operaciones de Redis (escrituras en caché, actualizaciones de etiquetas, recolección de elementos no utilizados) en un solo script atómico ejecutado en el lado del servidor mediante EVALSHA. Esto evita la intercalación de solicitudes simultáneas como, por ejemplo, garantizar que una entrada de caché y su pertenencia a una etiqueta se escriban juntas.
use_lua y use_lua_on_gc sin comprender las implicaciones para su versión de Adobe Commerce:use_lua: si se habilita esto en Adobe Commerce 2.4.7 o 2.4.8 (bibliotecacolinmollenhour/cache-backend-redis1.17.1), pueden dañarse las cachés y producirse problemas de pérdida de caché en GraphQL.use_lua_on_gc: al deshabilitar esto en Adobe Commerce 2.4.8, se elimina la protección atómica durante la recolección de elementos no utilizados y puede provocar que la invalidación de la caché basada en etiquetas falle de forma silenciosa, lo que requiere un vaciado de caché completo para recuperarse.
Comando de ejemplo (caché predeterminada)
En el siguiente ejemplo se habilita el almacenamiento en caché predeterminado de Redis, se establece el host en 127.0.0.1 y se asigna el número de base de datos a 0. Redis utiliza valores predeterminados para el resto de parámetros.
bin/magento setup:config:set --cache-backend=redis --cache-backend-redis-server=127.0.0.1 --cache-backend-redis-db=0
Configurar el almacenamiento en caché de páginas Redis
Para configurar el almacenamiento en caché de la página Redis en Commerce, ejecute el comando setup:config:set con parámetros adicionales.
bin/magento setup:config:set --page-cache=redis --page-cache-redis-<parameter>=<value>...
Con los siguientes parámetros:
-
--page-cache=redishabilita el almacenamiento en caché de páginas Redis. Si esta función ya se ha habilitado, omita este parámetro. -
--page-cache-redis-<parameter>=<value>es una lista de pares de clave y valor que configuran el almacenamiento en caché de la página:
page-cache-redis-server127.0.0.1page-cache-redis-port6379page-cache-redis-dbImportante: Si utiliza Redis para más de un tipo de almacenamiento en caché, los números de base de datos deben ser diferentes. Se recomienda asignar el número de base de datos de almacenamiento en caché predeterminado a 0, el número de base de datos de almacenamiento en caché de páginas a 1 y el número de base de datos de almacenamiento de sesión a 2.
0page-cache-redis-passwordauth, que requiere que los clientes se autentiquen para tener acceso a la base de datos. Configure la contraseña en el archivo de configuración de Redis: /etc/redis/redis.confEl ejemplo siguiente habilita el almacenamiento en caché de páginas de Redis, establece el host en 127.0.0.1 y asigna el número de base de datos a 1. El resto de parámetros se definen con el valor predeterminado.
bin/magento setup:config:set --page-cache=redis --page-cache-redis-server=127.0.0.1 --page-cache-redis-db=1
Revisar la configuración del entorno de Commerce
Al ejecutar los comandos para configurar el almacenamiento en caché de Redis, se actualiza la configuración del entorno de Commerce (<Commerce-install-dir>app/etc/env.php):
| code language-php |
|---|
|
| code language-php |
|---|
|
| note |
|---|
| NOTE |
A partir de Commerce 2.4.9, utilice el tipo de backend simplificado 'backend' => 'redis' en lugar de la ruta de clase completa. Symfony Cache se utiliza automáticamente cuando se especifica el nombre simplificado. |
Configurar opciones de almacenamiento en caché adicionales
Función de precarga Redis
Dado que Commerce almacena datos de configuración en la caché de Redis, puede cargar previamente datos que se reutilizan entre páginas. Para buscar las claves que deben cargarse previamente, analice los datos que se transfieren de Redis a Commerce. Adobe sugiere precargar los datos que se cargan en todas las páginas, como SYSTEM_DEFAULT, EAV_ENTITY_TYPES y DB_IS_UP_TO_DATE.
Redis usa pipeline para componer solicitudes de carga. Las claves deben incluir el prefijo de base de datos; por ejemplo, si el prefijo de base de datos es 061_, la clave de precarga tiene el siguiente aspecto: 061_SYSTEM_DEFAULT
| code language-php |
|---|
|
| code language-php |
|---|
|
Al utilizar la característica de precarga con una caché L2, debe agregar el sufijo :hash a las claves. La caché L2 transfiere únicamente el hash de los datos, no los datos reales.
'preload_keys' => [
'061_EAV_ENTITY_TYPES:hash',
'061_GLOBAL_PLUGIN_LIST:hash',
'061_DB_IS_UP_TO_DATE:hash',
'061_SYSTEM_DEFAULT:hash',
],
Generación paralela
A partir de la versión Commerce 2.4.0, Adobe introdujo la opción allow_parallel_generation para los usuarios que desean eliminar la espera de bloqueos. Está desactivada de forma predeterminada y Adobe recomienda desactivarla hasta que tenga configuraciones o bloques excesivos.
Para habilitar la generación paralela:
bin/magento setup:config:set --allow-parallel-generation
Como es un indicador, no puede deshabilitarlo con un comando. Establezca manualmente el valor de configuración en false:
| code language-php |
|---|
|
| code language-php |
|---|
|
Optimización del rendimiento de Symfony Cache
Si utiliza Symfony Cache, puede optimizar aún más el rendimiento configurando el serializador Igbinary, instalando la extensión PHP igbinary y la extensión phpredis, y habilitando conexiones persistentes.
Serializador igbinario
El serializador Igbinary proporciona mejoras significativas de rendimiento sobre la serialización predeterminada de PHP. Debe configurarse manualmente en app/etc/env.php:
'cache' => [
'frontend' => [
'default' => [
'backend_options' => [
'server' => 'redis',
'database' => '0',
'port' => '6379',
'serializer' => 'igbinary', // Enable Igbinary serialization
]
],
'page_cache' => [
'backend_options' => [
'server' => 'redis',
'database' => '1',
'port' => '6379',
'serializer' => 'igbinary', // Enable Igbinary for page cache too
]
]
]
]
Instale la extensión PHP Igbinary
Para utilizar la serialización igbinary, debe instalar la extensión PHP Igbinary.
Usando apt (recomendado para Debian/Ubuntu):
sudo apt-get install php-igbinary
sudo systemctl restart php-fpm
php -m | grep igbinary
Usando pecl (método alternativo):
sudo pecl install igbinary
echo "extension=igbinary.so" | sudo tee /etc/php/8.3/mods-available/igbinary.ini
sudo phpenmod igbinary
sudo systemctl restart php-fpm
php -m | grep igbinary
Extensiones de PHP Redis: phpredis vs Predis
Commerce 2.4.9+ incluye reserva automática entre phpredis (extensión nativa de C) y Predis (biblioteca PHP pura). Para obtener un rendimiento óptimo, instale phpredis:
Usando apt (recomendado para Debian/Ubuntu):
sudo apt-get install php-redis
sudo systemctl restart php-fpm
php -m | grep redis
Usando pecl (método alternativo):
sudo pecl install redis
echo "extension=redis.so" | sudo tee /etc/php/8.3/mods-available/redis.ini
sudo phpenmod redis
sudo systemctl restart php-fpm
php -m | grep redis
Comparación de rendimiento:
Conexiones persistentes
Las conexiones persistentes reutilizan las conexiones de Redis existentes entre solicitudes, lo que proporciona operaciones de caché un 5-15 % más rápidas. Configurar en app/etc/env.php:
'cache' => [
'frontend' => [
'default' => [
'backend_options' => [
'server' => 'redis',
'database' => '0',
'port' => '6379',
'persistent' => '1',
'persistent_id' => 'cache_default',
'timeout' => '2.5',
'read_timeout' => '2.0',
]
],
'page_cache' => [
'backend_options' => [
'server' => 'redis',
'database' => '1',
'port' => '6379',
'persistent' => '1',
'persistent_id' => 'cache_fpc',
]
]
]
]
persistent_id único para cada tipo de caché a fin de evitar conflictos de conexión.Configuración optimizada completa
Esta es una configuración de Symfony lista para la producción que combina todas las optimizaciones de rendimiento:
'cache' => [
'frontend' => [
'default' => [
'id_prefix' => 'b0b_',
'backend' => 'redis',
'backend_options' => [
'server' => 'redis',
'database' => '0',
'port' => '6379',
'serializer' => 'igbinary',
'compress_data' => '1',
'compression_lib' => 'gzip',
'persistent' => '1',
'persistent_id' => 'cache_default',
'timeout' => '2.5',
'read_timeout' => '2.0',
'use_lua' => '1',
'use_lua_on_gc' => '1',
'preload_keys' => [
'b0b_EAV_ENTITY_TYPES',
'b0b_GLOBAL_PLUGIN_LIST',
'b0b_DB_IS_UP_TO_DATE',
'b0b_SYSTEM_DEFAULT',
],
]
],
'page_cache' => [
'id_prefix' => 'b0b_',
'backend' => 'redis',
'backend_options' => [
'server' => 'redis',
'database' => '1',
'port' => '6379',
'serializer' => 'igbinary',
'compress_data' => '0',
'persistent' => '1',
'persistent_id' => 'cache_fpc',
]
]
],
'allow_parallel_generation' => false
]
Compruebe la conexión de Redis
Para comprobar que Redis y Commerce funcionan juntos correctamente:
- Inicie sesión en el servidor que ejecuta Redis y Commerce.
- Abra un terminal.
- Compruebe la conexión utilizando el comando
redis-cli monitoro el comandoredis-cli ping.
Si los comandos se ejecutan correctamente, Redis se está ejecutando y puede comunicarse con la aplicación de Commerce. Si se producen errores, existe un problema de conexión entre Redis y Commerce que debe resolver.
Redis monitor, comando
redis-cli monitor
Ejemplo de salida de almacenamiento en caché de páginas:
1476826133.810090 [0 127.0.0.1:52366] "select" "1"
1476826133.816293 [0 127.0.0.1:52367] "select" "0"
1476826133.817461 [0 127.0.0.1:52367] "hget" "zc:k:ea6_GLOBAL__DICONFIG" "d"
1476826133.829666 [0 127.0.0.1:52367] "hget" "zc:k:ea6_DICONFIG049005964B465901F774DB9751971818" "d"
1476826133.837854 [0 127.0.0.1:52367] "hget" "zc:k:ea6_INTERCEPTION" "d"
1476826133.868374 [0 127.0.0.1:52368] "select" "1"
1476826133.869011 [0 127.0.0.1:52369] "select" "0"
1476826133.869601 [0 127.0.0.1:52369] "hget" "zc:k:ea6_DEFAULT_CONFIG_CACHE_DEFAULT__10__235__32__1080MAGENTO2" "d"
1476826133.872317 [0 127.0.0.1:52369] "hget" "zc:k:ea6_INITIAL_CONFIG" "d"
1476826133.879267 [0 127.0.0.1:52369] "hget" "zc:k:ea6_GLOBAL_PRIMARY_PLUGIN_LIST" "d"
...
Si ambos comandos se ejecutan correctamente, Redis se configura correctamente.
Inspeccionar datos comprimidos
Para inspeccionar los datos de sesión comprimidos y la caché de página, use la herramienta RESP.app. Admite la descompresión automática de los datos de caché de página y sesión de Commerce 2 y muestra los datos de sesión de PHP en un formato legible en lenguaje natural.