En esta página, se describe cómo habilitar o inhabilitar el motor columnar 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, así como la configuración de la memoria y el caché de almacenamiento para un rendimiento óptimo.
Para usar el motor de columnas cuando uses 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 las 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 columnar 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. Dedicar RAM de alta velocidad a tu almacén de columnas garantiza que AlloyDB pueda acceder a los datos de columnas lo más rápido posible.
La memoria y la caché de almacenamiento juntas representan la capacidad general del motor de columnas.
Configura la memoria para el motor de columnas
Si el almacén de columnas se vuelve más grande que la porción asignada de la memoria de tu instancia, AlloyDB usará 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 un máximo del 50%. Para encontrar el tamaño de memoria recomendado del motor de columnas para tu instancia, consulta Cómo recomendar el tamaño de la 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 configurar o borrar marcas, consulta Configura las marcas de base de datos de una instancia.
Configura la caché de almacenamiento para el motor de columnas
La caché de almacenamiento del motor de columnas se aprovisiona según el nivel de la instancia.
Nivel de la instancia | Tamaño predeterminado de la caché del motor de columnas | ||
---|---|---|---|
N2 | C4A | ||
Principal | Grupo de réplicas | Grupo principal o de réplicas | |
1 CPU virtual | N/A | N/A | 0 |
2 vCPU | 18.75 GB | 37.5 GB | N/A |
4 CPU virtuales | 18.75 GB | 37.5 GB | 18.75 GB |
8 CPU virtuales | 18.75 GB | 37.5 GB | 37.75 GB |
16 CPU virtuales | 37.5 GB | 37.5 GB | 75 GB |
32 CPU virtual | 75 GB | 75 GB | 112.5 GB |
48 CPU virtuales | N/A | N/A | 187.5 GB |
64 CPU virtuales | 150 GB | 150 GB | 262.5 GB |
72 CPU virtuales | N/A | N/A | 300 GB |
96 CPU virtuales | 300 GB | 300 GB | N/A |
128 CPU virtuales | 450 GB | 450 GB | N/A |
La marca google_columnar_engine.storage_cache_size
te permite ajustar la caché de almacenamiento del motor columnar, con las limitaciones de los valores mínimos y máximos que se indican en la siguiente tabla:
Nivel de la instancia | Tamaño mínimo de la caché del motor de columnas | Tamaño máximo de la caché del motor de columnas | ||
---|---|---|---|---|
N2 | C4A | |||
Principal | Grupo de réplicas | Grupo principal o de réplicas | ||
1 CPU virtual | N/A | N/A | N/A | 0 |
2 vCPU | 0 | 187.5 GB | 375 GB | N/A |
4 CPU virtuales | 0 | 187.5 GB | 375 GB | 187.5 GB |
8 CPU virtuales | 0 | 187.5 GB | 375 GB | 375 GB |
16 CPU virtuales | 0 | 375 GB | 375 GB | 750 GB |
32 CPU virtual | 0 | 750 GB | 750 GB | 1,125 GB |
48 CPU virtuales | N/A | N/A | N/A | 1,125 GB |
64 CPU virtuales | 0 | 1,500 GB | 1,500 GB | 2,625 GB |
72 CPU virtuales | N/A | N/A | N/A | 3000 GB |
96 CPU virtuales | 0 | 3000 GB | 3000 GB | N/A |
128 CPU virtuales | 0 | 4,500 GB | 4,500 GB | N/A |
Supervisa los datos de la caché de almacenamiento del motor de columnas
Para ver información sobre la caché de almacenamiento del motor columnar, puedes ejecutar una de las siguientes consultas en SQL.
Consulta en SQL | Descripción |
---|---|
SELECT google_columnar_engine_storage_cache_used(); |
Devuelve el tamaño de la caché de almacenamiento del motor de columnas que se usa. |
SELECT google_columnar_engine_storage_cache_available(); |
Devuelve el tamaño de la caché de almacenamiento del motor de columnas sin usar. |
SELECT google_columnar_engine_storage_cache_total(); |
Devuelve la cantidad total del tamaño configurado de la caché de almacenamiento para el motor de columnas. |
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 aptas.
Después de habilitar la unión vectorizada, el optimizador 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. El optimizador toma esta decisión comparando el costo de ejecutar la consulta con cada método.
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. Puedes aumentar la cantidad de subprocesos disponibles para esta función configurando la marca google_columnar_engine.vectorized_join_threads
en un valor mayor.
Actualiza manualmente tu motor de columnas
De forma predeterminada, el motor columnar 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 del motor de columnas
Si las columnas no se propagan en el motor columnar, 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 se encuentren en el motor columnar.
Verifica el uso del motor de columnas con la instrucción
EXPLAIN
.
¿Qué sigue?
Consulta la lista completa de marcas de bases de datos del motor columnar.
Obtén más información sobre la columna automática.