- usar el motor de tabla
PostgreSQLpara leer desde una tabla de PostgreSQL - usar el motor de base de datos experimental
MaterializedPostgreSQLpara sincronizar una base de datos de PostgreSQL con una base de datos de ClickHouse
Uso del motor de tabla PostgreSQL
PostgreSQL permite realizar operaciones SELECT e INSERT sobre datos almacenados en un servidor PostgreSQL remoto desde ClickHouse.
Este artículo ilustra métodos básicos de integración usando una sola tabla.
1. Configuración de PostgreSQL
- En
postgresql.conf, agregue la siguiente entrada para que PostgreSQL escuche en las interfaces de red:
- Cree un usuario para que ClickHouse se conecte. Con fines de demostración, este ejemplo le concede privilegios completos de superusuario.
- Cree una nueva base de datos en PostgreSQL:
- Cree una tabla nueva:
- Agreguemos unas cuantas filas para probar:
- Para configurar PostgreSQL de modo que permita conexiones a la nueva base de datos con el nuevo usuario para la replicación, agrega la siguiente entrada al archivo
pg_hba.conf. Actualiza la línea de dirección con la subred o la dirección IP de tu servidor de PostgreSQL:
- Recarga la configuración
pg_hba.conf(ajusta este comando según tu versión):
- Verifique que el nuevo
clickhouse_userpueda iniciar sesión:
Si estás usando esta función en ClickHouse Cloud, puede que necesites permitir el acceso a tu instancia de PostgreSQL desde las direcciones IP de ClickHouse Cloud.
Consulta la Cloud Endpoints API de ClickHouse para obtener información sobre el tráfico de salida.
2. Defina una tabla en ClickHouse
- Inicie sesión en el cliente
clickhouse-client:
- Vamos a crear una nueva base de datos:
- Cree una tabla que use
PostgreSQL:
| parámetro | Descripción | ejemplo |
|---|---|---|
| host:port | nombre de host o dirección IP y puerto | postgres-host.domain.com:5432 |
| database | nombre de la base de datos de PostgreSQL | db_in_psg |
| user | nombre de usuario para conectarse a Postgres | clickhouse_user |
| password | contraseña para conectarse a Postgres | ClickHouse_123 |
Consulte la página de documentación de PostgreSQL table engine para ver la lista completa de parámetros.
3 Probar la integración
- En ClickHouse, consulte las filas iniciales:
- De nuevo en PostgreSQL, añada un par de filas a la tabla:
- Esas dos filas nuevas deberían aparecer en tu tabla de ClickHouse:
- Veamos qué ocurre cuando añades filas a la tabla de ClickHouse:
- Las filas agregadas en ClickHouse deberían aparecer en la tabla de PostgreSQL:
PostrgeSQL.
Consulta la página de documentación del motor de tabla PostgreSQL para ver más funcionalidades, como especificar esquemas, devolver solo un subconjunto de columnas y conectarse a varias réplicas. Consulta también el blog ClickHouse and PostgreSQL - a match made in data heaven - part 1.
Uso del motor de base de datos MaterializedPostgreSQL
1. En PostgreSQL
- En
postgresql.conf, configure los niveles mínimos de escucha, el nivel WAL de replicación y los slots de replicación:
logical y al menos 2 slots de replicación
- Con una cuenta de administrador, cree un usuario para conectarse desde ClickHouse:
- cree una nueva base de datos:
- conéctese a la nueva base de datos desde
psql:
- cree una nueva tabla:
- añade las filas iniciales:
- Configure PostgreSQL para permitir conexiones a la nueva base de datos con el nuevo usuario de replicación. A continuación se muestra la entrada mínima que se debe añadir al archivo
pg_hba.conf:
address con la subred o la dirección del servidor, según la documentación de PostgreSQL
- vuelva a cargar la configuración de
pg_hba.confcon algo como esto (ajústelo según su versión):
- Pruebe a iniciar sesión con el nuevo
clickhouse_user:
2. En ClickHouse
- acceda a la ClickHouse CLI
- Habilite la función experimental de PostgreSQL para el motor de base de datos:
- Cree la nueva base de datos que se va a replicar y defina la tabla inicial:
| parameter | Descripción | ejemplo |
|---|---|---|
| host:port | nombre de host o dirección IP y puerto | postgres-host.domain.com:5432 |
| database | nombre de la base de datos PostgreSQL | db1 |
| user | nombre de usuario para conectarse a Postgres | clickhouse_user |
| password | contraseña para conectarse a Postgres | ClickHouse_123 |
| settings | configuración adicional para el motor | materialized_postgresql_tables_list = ‘table1’ |
Para consultar la guía completa del motor de base de datos PostgreSQL, consulte https://clickhouse.com/docs/engines/database-engines/materialized-postgresql/#settings
- Compruebe que la tabla inicial tenga datos:
3. Probar la replicación básica
- En PostgreSQL, agregue nuevas filas:
- En ClickHouse, verifica que las nuevas filas estén visibles:
4. Resumen
Para conocer más funcionalidades disponibles en las opciones avanzadas, consulte la documentación de referencia.