pglogical.
Para obtener una descripción general de pglogical en AlloyDB Omni, sus beneficios y limitaciones, consulta Acerca de la extensión pglogical.
Componentes clave de pglogical
Los componentes clave de la extensión pglogical son los siguientes:
- Nodo: Es la referencia que se le da a la base de datos dentro de un clúster de PostgreSQL.
La extensión
pglogicalse instala y funciona en cualquier cantidad de bases de datos dentro del clúster, y cada una actúa como un nodo pglogical distinto. Cada nodo puede ser un proveedor, también conocido como fuente de replicación, o un suscriptor, también conocido como destino de replicación, o ambos de forma simultánea. Solo se permite un nodo por base de datos. - Conjunto de replicación: Se define en la base de datos del proveedor como una agrupación lógica de
tablas y secuencias que se migrarán, y las instrucciones SQL, como
INSERT, UPDATE, DELETE, TRUNCATE, que deben replicarse. Puedes asignar tablas a más de un conjunto de replicación. De forma predeterminada, se proporcionan tres conjuntos de replicación preconfigurados, comodefault,default_insert_onlyyddl_sql, y puedes agregar cualquier cantidad de conjuntos de replicación adicionales para satisfacer tus necesidades. - Suscripción: Proporciona detalles de los cambios que se replican desde las bases de datos del proveedor
y los cambios que se replican desde las bases de datos del proveedor en la base de datos del suscriptor. La suscripción especifica la base de datos del proveedor a través de una cadena de conexión y, de forma opcional, qué conjuntos de replicación de ese proveedor se deben copiar. Además, también puedes especificar si deseas usar
apply delaycuando creas la suscripción.
En esta implementación, el servicio de AlloyDB para PostgreSQL es el proveedor y AlloyDB Omni local es el suscriptor. Ten en cuenta que también es posible la configuración opuesta.
Métodos de autenticación compatibles
Debes tener en cuenta la red y la seguridad entre los nodos de replicación antes de implementar la extensión pglogical en AlloyDB Omni.
Los dos métodos de autenticación principales
que se usan con la extensión pglogical son los métodos de autenticación de contraseña y de confianza.
El método de autenticación recomendado es la autenticación de confianza, ya que, en el método de autenticación de contraseña, las contraseñas se almacenan en formato de texto sin formato en las tablas de la base de datos que son propiedad de pglogical. Estas contraseñas son visibles en texto sin
formato para cualquier persona con permisos de base de datos para consultar estas tablas, en copias de seguridad no binarias,
y en los archivos de registro de PostgreSQL.
Si usas el método de autenticación de confianza, debes realizar entradas específicas en el archivo de autenticación basado en host, pg_hba.conf, para obtener la máxima seguridad. Puedes restringir el acceso especificando las bases de datos de destino, permitiendo solo la opción de replicación o bases de datos específicas, el usuario de replicación y solo desde la dirección IP específica del suscriptor.
Antes de comenzar
Puedes instalar pglogical como una extensión dentro de una base de datos determinada.
Antes de implementar la extensión pglogical en AlloyDB Omni, asegúrate de cumplir con los siguientes requisitos del sistema:
- Un clúster de AlloyDB para PostgreSQL y acceso de lectura/escritura a la instancia principal como administrador de Cloud AlloyDB. Para obtener instrucciones sobre cómo aprovisionar un clúster de AlloyDB para PostgreSQL, consulta Crea una base de datos y conéctate a ella.
- Un servidor de AlloyDB Omni instalado y configurado. Para obtener instrucciones sobre cómo instalar AlloyDB Omni, consulta Instala AlloyDB Omni.
- Las direcciones IP de la instancia principal de AlloyDB para PostgreSQL y del servidor host de AlloyDB Omni.
- Una red establecida y segura entre AlloyDB para PostgreSQL y el servidor host de AlloyDB Omni. Se requiere conectividad TCP en el puerto estándar de PostgreSQL de 5432.
Ajusta los parámetros en el proveedor de AlloyDB para PostgreSQL
La extensión pglogical requiere un conjunto mínimo de ajustes de parámetros en el clúster del proveedor de AlloyDB para PostgreSQL. Debes establecer el
wal_level parámetro en logical, y agregar pglogical al shared_preload_libraries
parámetro en el postgresql.conf archivo.
cp postgresql.conf postgresql.baksed -r -i "s|(\#)?wal_level\s*=.*|wal_level=logical|" postgresql.confsed -r -i "s|(\#)?(shared_preload_libraries\s*=\s*)'(.*)'.*$|\2'\3,pglogical'|" postgresql.confsed -r -i "s|',|'|" postgresql.conf
En el servicio de AlloyDB para PostgreSQL, puedes ajustar los parámetros configurando las marcas de clúster adecuadas.
Debes ajustar los parámetros de las siguientes marcas de AlloyDB para PostgreSQL:
alloydb.enable_pglogical = onalloydb.logical_decoding = on
Para obtener información sobre cómo configurar marcas de base de datos en AlloyDB para PostgreSQL, consulta Configura las marcas de base de datos de una instancia.
Para los otros parámetros de base de datos de nodo de proveedor obligatorios, debes establecer los valores predeterminados de AlloyDB para PostgreSQL de la siguiente manera:
max_worker_processes: Uno por base de datos del proveedor y al menos uno por nodo del suscriptor. Al menos 10 es el estándar para este parámetro.max_replication_slots: Uno por nodo en los nodos del proveedor.max_wal_senders: Uno por nodo en los nodos del proveedor.track_commit_timestamp: Se establece enonsi se requiere la resolución de conflictos de la última o primera actualización.listen_addresses: Debe incluir la dirección IP de AlloyDB Omni o mencionarla a través de un bloque CIDR de cobertura.
Puedes verificar estos parámetros con cualquier herramienta de consulta, como psql.
Ajusta los parámetros en el clúster del suscriptor de AlloyDB Omni
La extensión pglogical también requiere un conjunto mínimo de ajustes de parámetros en el suscriptor de AlloyDB Omni. Debes agregar pglogical
al parámetro shared_preload_libraries en el archivo DATA_DIR/postgresql.conf. Si alguna base de datos dentro del clúster actúa como base de datos del proveedor, realiza los cambios de parámetros necesarios para las bases de datos del proveedor.
Reemplaza DATA_DIR por la ruta de acceso del sistema de archivos a tu directorio de datos, por ejemplo, /home/$USER/alloydb-data.
Ajusta los parámetros:
sudo sed -r -i "s|(shared_preload_libraries\s*=\s*)'(.*)'.*$|\1'\2,pglogical'|" DATA_DIR/postgresql.confVerifica que el parámetro esté configurado correctamente:
grep -iE 'shared_preload_libraries' DATA_DIR/postgresql.confReinicia AlloyDB Omni para que el cambio de parámetro surta efecto:
Docker
docker container restart CONTAINER_NAMEReemplaza
CONTAINER_NAMEpor el nombre que le asignaste al contenedor de AlloyDB Omni cuando lo instalaste.Podman
podman container restart CONTAINER_NAMEReemplaza
CONTAINER_NAMEpor el nombre que le asignaste al contenedor de AlloyDB Omni cuando lo instalaste.Establece los valores predeterminados de AlloyDB Omni para otros parámetros de la base de datos del proveedor:
max_worker_processes: Uno por base de datos del proveedor y uno por nodo del suscriptor.track_commit_timestamp: Se establece enonsi se requiere la resolución de conflictos de la última o primera actualización.
Confirma que todos los valores de los parámetros estén configurados correctamente:
Docker
docker exec CONTAINER_NAME psql -h localhost -U postgres -c " SELECT name, setting FROM pg_catalog.pg_settings WHERE name IN ('listen_addresses', 'wal_level', 'shared_preload_libraries', 'max_worker_processes', 'max_replication_slots', 'max_wal_senders', 'track_commit_timestamp') ORDER BY name;"Podman
podman exec CONTAINER_NAME psql -h localhost -U postgres -c " SELECT name, setting FROM pg_catalog.pg_settings WHERE name IN ('listen_addresses', 'wal_level', 'shared_preload_libraries', 'max_worker_processes', 'max_replication_slots', 'max_wal_senders', 'track_commit_timestamp') ORDER BY name;"
Ajustes de autenticación basados en host en el clúster del suscriptor de AlloyDB Omni
pglogical realiza conexiones TCP locales a la base de datos del suscriptor de AlloyDB Omni. Por lo tanto, debes agregar la dirección IP del servidor host del suscriptor a
el archivo DATA_DIR/pg_hba.conf de AlloyDB Omni.
Agrega una entrada de autenticación de confianza para el servidor local, específica para un nuevo
pglogical_replicationusuario, alDATA_DIR/pg_hba.confarchivo:echo -e "# pglogical entries: host all pglogical_replication samehost trust " | column -t | sudo tee -a DATA_DIR/pg_hba.confVerifica que la entrada sea correcta:
tail -2 DATA_DIR/pg_hba.confReinicia AlloyDB Omni para que el cambio de autenticación surta efecto:
Docker
docker container restart CONTAINER_NAMEPodman
podman container restart CONTAINER_NAME
Crea un usuario pglogical en clústeres de proveedor y suscriptor
Debes crear un usuario nuevo en el clúster del proveedor y del suscriptor.
pglogical requiere que el usuario tenga los permisos superuser y replication.
En el clúster del proveedor de AlloyDB para PostgreSQL, crea el usuario y otorga el rol
alloydbsuperuser:CREATE USER pglogical_replication LOGIN PASSWORD 'secret'; ALTER USER pglogical_replication WITH replication; GRANT alloydbsuperuser TO pglogical_replication;En el clúster del suscriptor de AlloyDB Omni, crea el usuario y otorga los atributos
replicationysuperuser:CREATE USER pglogical_replication LOGIN PASSWORD 'secret'; ALTER USER pglogical_replication WITH replication; ALTER USER pglogical_replication WITH superuser;
Agrega pglogical y nodos a la base de datos del proveedor de AlloyDB para PostgreSQL
Otorga los privilegios necesarios.
Debes instalar la extensión
pglogicalen cada base de datos y otorgar el permisousageal usuario de la base de datos pglogical. En AlloyDB para PostgreSQL, debes otorgar privilegios en el esquemapglogical.Por ejemplo, si tu base de datos es
my_test_db, ejecuta el siguiente comando en la base de datos del proveedor de AlloyDB para PostgreSQL:\c my_test_db; CREATE EXTENSION IF NOT EXISTS pglogical; GRANT usage ON SCHEMA pglogical TO pglogical_replication; -- For Google Cloud AlloyDB we also need to manually grant privileges: GRANT ALL PRIVILEGES ON ALL tables IN SCHEMA pglogical TO pglogical_replication;Crea un nodo
pglogicalpara las bases de datos del proveedor.node_namees arbitrario y la cadenadsndebe ser una conexión TCP válida a la misma base de datos. Para AlloyDB para PostgreSQL, la parte host dedsnes la dirección IP proporcionada para la instancia principal.En AlloyDB para PostgreSQL, no se permite la autenticación de confianza, y el argumento de contraseña debe incluirse en el parámetro
dsn. parámetro.Por ejemplo, para la base de datos
my_test_db, ejecuta el siguiente comando:SELECT pglogical.create_node(node_name := 'provider', dsn := 'host=SERVER_IP_ADDRESS port=5432 dbname=my_test_db user=pglogical_replication password=secret');
Crea una tabla y agrégala al conjunto de replicación predeterminado
Crea una tabla y agrégala al conjunto de replicación predeterminado en la base de datos del proveedor de AlloyDB para PostgreSQL.
Crea una tabla de prueba llamada
test_table_1en la base de datos del proveedor:CREATE TABLE test_table_1 (col1 INT PRIMARY KEY); INSERT INTO test_table_1 VALUES (1),(2),(3);Otorga
SELECTen las tablas individuales o ejecuta el comandoGRANT SELECT ON ALL TABLES. Cualquier tabla que forme parte de un conjunto de replicación debe tener permiso de consulta otorgado al usuario de replicación,pglogical_replication.GRANT SELECT ON ALL TABLES IN SCHEMA public TO pglogical_replication;Agrega manualmente la tabla de prueba al conjunto de replicación predeterminado. Puedes crear conjuntos de replicación pglogical personalizados o usar los conjuntos de replicación predeterminados. Se crearon varios conjuntos de replicación predeterminados, como
default,default_insert_only, yddl_sql, cuando creaste la extensión. Puedes agregar tablas y secuencias a los conjuntos de replicación de forma individual o todas a la vez para un esquema especificado.-- Add the specified table to the default replication set: SELECT pglogical.replication_set_add_table(set_name := 'default', relation := 'test_table_1', synchronize_data := TRUE); -- Check which tables have been added to all replication sets: SELECT * FROM pglogical.replication_set_table;(Opcional) Agrega todas las tablas en un esquema especificado, como
public:-- Add all "public" schema tables to the default replication set: SELECT pglogical.replication_set_add_all_tables('default', ARRAY['public']); -- Check which tables have been added to all replication sets: SELECT * FROM pglogical.replication_set_table; -- Add all "public" schema sequences to the default replication: SELECT pglogical.replication_set_add_all_sequences('default', ARRAY['public']); -- Check which sequences have been added to all replication sets: SELECT * FROM pglogical.replication_set_seq;Quita la tabla del conjunto de replicación
default. Si hay tablas en el esquema que no tienen una clave primaria, puedes configurarla solo para la replicación de INSERT o establecer las columnas que identifican de forma única la fila con la funciónREPLICA IDENTITYque se usa con el comandoALTER TABLE. Si agregaste esas tablas al conjunto de replicacióndefaultautomáticamente con la funciónreplication_set_add_all_tables, debes quitarlas manualmente de ese conjunto de replicación y agregarlas al conjuntodefault_insert_only.-- Remove the table from the **default** replication set: SELECT pglogical.replication_set_remove_table(set_name := 'default', relation := 'test_table_2');-- Manually add to the **default_insert_only** replication set: SELECT pglogical.replication_set_add_table(set_name := 'default_insert_only', relation := 'test_table_2');De manera opcional, si deseas agregar las tablas recién creadas al conjunto de replicación automáticamente, agrega el
pglogical_assign_repsetactivador como se sugiere en lapglogicalfuente.
Copia la base de datos en el clúster del suscriptor de AlloyDB Omni
Crea una copia de seguridad solo del esquema de la base de datos de origen con la utilidad
pg_dump.Ejecuta el comando
pg_dumpdesde tu servidor de suscriptor de AlloyDB Omni con la dirección IP de la instancia principal de AlloyDB para PostgreSQL.pg_dump -h SERVER_IP_ADDRESS -U postgres --create --schema-only my_test_db > my_test_db.schema-only.sqlImporta la copia de seguridad a la base de datos del suscriptor en el servidor AlloyDB Omni del suscriptor:
Docker
docker exec -i CONTAINER_NAME psql -h localhost -U postgres < my_test_db.schema-only.sqlPodman
podman exec -i CONTAINER_NAME psql -h localhost -U postgres < my_test_db.schema-only.sql
Ignora errores como alloydbsuperuser not existing. Este rol es específico de AlloyDB para PostgreSQL.
Esto crea la base de datos y el esquema, sin ninguno de los datos de la fila. La extensión pglogical replica los datos de la fila. Copia o vuelve a crear manualmente cualquier otro usuario o rol que sea necesario.
Crea un nodo y una suscripción en la base de datos del suscriptor de AlloyDB Omni
Crea un nodo en la base de datos del suscriptor de AlloyDB Omni:
Docker
docker exec CONTAINER_NAME psql -h localhost -U postgres -d my_test_db -c " SELECT pglogical.create_node(node_name := 'subscriber', dsn := 'host=localhost port=5432 dbname=my_test_db user=pglogical_replication');"Podman
podman exec CONTAINER_NAME psql -h localhost -U postgres -d my_test_db -c " SELECT pglogical.create_node(node_name := 'subscriber', dsn := 'host=localhost port=5432 dbname=my_test_db user=pglogical_replication');"Crea una suscripción en la base de datos del suscriptor, que apunte a la instancia principal de la base de datos del proveedor de AlloyDB para PostgreSQL.
Docker
docker exec CONTAINER_NAME psql -h localhost -U postgres -d my_test_db -c " SELECT pglogical.create_subscription(subscription_name := 'test_sub_1', provider_dsn := 'host=SERVER_IP_ADDRESS port=5432 dbname=my_test_db user=pglogical_replication password=secret');"Podman
podman exec CONTAINER_NAME psql -h localhost -U postgres -d my_test_db -c " SELECT pglogical.create_subscription(subscription_name := 'test_sub_1', provider_dsn := 'host=SERVER_IP_ADDRESS port=5432 dbname=my_test_db user=pglogical_replication password=secret');"Según el tamaño de la tabla y los datos que se replicarán, el tiempo de replicación puede variar de segundos a minutos, después de lo cual los datos iniciales deberían haberse replicado del proveedor al suscriptor:
Docker
docker exec CONTAINER_NAME psql -h localhost -U postgres -d my_test_db -c " SELECT * FROM test_table_1 ORDER BY 1;"Podman
podman exec CONTAINER_NAME psql -h localhost -U postgres -d my_test_db -c " SELECT * FROM test_table_1 ORDER BY 1;"Las filas adicionales que se agregan a la base de datos del proveedor también se replican en segundos.
Consideraciones adicionales sobre la implementación de pglogical
La extensión pglogical tiene muchas funciones avanzadas que no se tratan en este documento.
Muchas de estas funciones son aplicables a tu implementación. Puedes considerar las siguientes funciones avanzadas:
- Resolución de conflictos
- Replicación bidireccional y de varios maestros
- Inclusión de secuencias
- Procedimientos de cambio y conmutación por error
¿Qué sigue?
- Replica datos entre AlloyDB Omni y otras bases de datos
- Cambio y conmutación por error con la replicación
pglogical