En esta página, se describe cómo habilitar o inhabilitar el motor de columnas en una instancia de AlloyDB para PostgreSQL. También se explica cómo configurar un tamaño inicial adecuado para su almacén de columnas.
Para usar el motor de columnas cuando usas AlloyDB Omni, consulta Cómo habilitar el motor de columnas en AlloyDB Omni.
Cada una de estas acciones implica cambiar el valor de una marca de base de datos en una de tus instancias de AlloyDB. Para obtener más información sobre cómo configurar marcas de base de datos, consulta Configura marcas de base de datos de una instancia.
Para obtener una descripción general conceptual del motor de columnas de AlloyDB, consulta Acerca del motor de columnas de AlloyDB.
Habilita el motor de columnas
Para usar el motor de columnas en una instancia, establece la marca google_columnar_engine.enabled
de la instancia en on
.
Para obtener más información sobre cómo configurar marcas de base de datos en AlloyDB, consulta Configura las marcas de base de datos de una instancia.
Configura el tamaño del almacén de columnas
Mientras el motor de columnas está habilitado en una instancia, AlloyDB asigna una parte de la memoria de la instancia para almacenar sus datos de columnas. Si dedicas RAM de alta velocidad a tu almacén de columnas, seguro que AlloyDB puede acceder a los datos de columnas lo más rápido posible.
Si el almacén de columnas se vuelve más grande que la parte asignada de la memoria de tu instancia, AlloyDB usa automáticamente la capa de caché subyacente de la instancia para almacenar los datos de columnas adicionales.De forma predeterminada, AlloyDB asigna el 30% de la memoria de la instancia al almacén de columnas y ajusta automáticamente la asignación total si cambias el tamaño de la instancia. Puedes modificar la memoria de la instancia hasta en un 50% como máximo. Para encontrar el tamaño de memoria del motor de columnas recomendado para tu instancia, consulta Cómo recomendar el tamaño de memoria del almacén de columnas.
También puedes establecer la asignación en un tamaño fijo y específico con la marca google_columnar_engine.memory_size_in_mb
.
Para que AlloyDB vuelva a la asignación predeterminada, quita la marca de la instancia.
Para obtener más información sobre cómo establecer o borrar marcas, consulta Configura las marcas de base de datos de una instancia.
Habilita la unión vectorizada
El motor de columnas tiene una función de unión vectorizada que puede mejorar el rendimiento de las uniones aplicando el procesamiento vectorizado a las consultas que cumplen con los requisitos.
Después de habilitar la unión vectorizada, el planificador de consultas de AlloyDB tiene la opción de aplicar el operador de unión vectorizada en lugar del operador de unión hash estándar de PostgreSQL. Para tomar esta decisión, el planificador compara el costo de ejecutar la consulta con cualquiera de los métodos.
Para habilitar la unión vectorizada en una instancia, establece la marca google_columnar_engine.enable_vectorized_join
de la instancia en on
.
De forma predeterminada, AlloyDB asigna un subproceso a la función de unión vectorizada. Para aumentar la cantidad de subprocesos disponibles para esta función, establece la marca google_columnar_engine.vectorized_join_threads
en un valor mayor.
Actualiza manualmente el motor de columnas
De forma predeterminada, el motor de columnas está configurado para actualizar automáticamente el almacén de columnas en segundo plano cuando está habilitado. Es posible que debas actualizar manualmente el almacén columnar en ciertas situaciones, por ejemplo, si la actualización automática no actualiza una relación con una gran cantidad de bloques no válidos.
Para actualizar manualmente el motor de columnas, ejecuta la siguiente consulta en SQL:
SELECT google_columnar_engine_refresh('TABLE_NAME');
Reemplaza TABLE_NAME
por el nombre de la tabla o la vista materializada que
deseas actualizar de forma manual.
Inhabilita el motor de columnas
Para inhabilitar el motor de columbar en una instancia, establece la marca google_columnar_engine.enabled
en off
.
Después de configurar esta marca, la instancia se reinicia automáticamente.
Soluciona problemas relacionados con el motor de columnas
Si las columnas no se propagan en el motor de columnas, es posible que se cumpla una de las siguientes situaciones:
Las columnas que deseas agregar incluyen un tipo de datos no admitido.
No se cumplen los requisitos del motor de columnas.
Para encontrar la causa de este problema, prueba lo siguiente:
Revisa los registros de auditoría de tu instancia.
Confirma que las tablas o las vistas materializadas de nuestra consulta estén en el motor de columnas.
Verifica el uso del motor de columnas con la sentencia
EXPLAIN
.
¿Qué sigue?
Consulta la lista completa de marcas de la base de datos del motor de columnas.
Obtén más información sobre la columnarización automática.