Configura una base de datos de Cloud SQL para PostgreSQL

En las siguientes secciones, se explica cómo configurar una base de datos de Cloud SQL para PostgreSQL.

Habilitar la replicación lógica

  1. Navega a Cloud SQL en la consola de Google Cloud.

  2. Abre la instancia de Cloud SQL y haz clic en EDITAR.

  3. Ve a la sección Marcas.

  4. Haz clic en AGREGAR MARCA.

  5. Elige la marca cloudsql.logical_decoding en el menú desplegable.

  6. Establece el valor de la marca en on.

  7. Haz clic en GUARDAR para guardar los cambios. Deberás reiniciar la instancia para actualizarla con los cambios.

  8. Una vez que se haya reiniciado la instancia, confirma los cambios en Marcas de base de datos en la página Descripción general.

Crea una publicación y una ranura de replicación

  1. Conéctate a la base de datos como un usuario con privilegios suficientes para crear una ranura de replicación. De lo contrario, ejecuta el siguiente comando:

    ALTER USER USER_NAME WITH REPLICATION;
    

    Reemplaza lo siguiente:

    • USER_NAME: Es el nombre del usuario al que deseas otorgar privilegios de replicación.
  2. Crea una publicación. Te recomendamos que crees una publicación solo para las tablas que quieres replicar. Esto permite que Datastream solo lea los datos relevantes y reduce la carga en la base de datos y en Datastream:

    CREATE PUBLICATION PUBLICATION_NAME
    FOR TABLE SCHEMA1.TABLE1, SCHEMA2.TABLE2;

    Reemplaza lo siguiente:

    • PUBLICATION_NAME: Es el nombre de la publicación. Deberás proporcionar este nombre cuando crees una transmisión en el asistente de creación de flujos de Datastream.
    • SCHEMA: Es el nombre del esquema que contiene la tabla.
    • TABLE: Es el nombre de la tabla que deseas replicar.

    Puedes crear una publicación para todas las tablas de un esquema. Este enfoque te permite replicar los cambios de las tablas en la lista de esquemas especificada, incluidas las tablas que crees en el futuro:

    CREATE PUBLICATION PUBLICATION_NAME
    FOR TABLES IN SCHEMA1, SCHEMA2;

    También puedes crear una publicación para todas las tablas de tu base de datos. Ten en cuenta que este enfoque aumenta la carga en la base de datos de origen y en Datastream:

    CREATE PUBLICATION PUBLICATION_NAME FOR ALL TABLES;
    
  3. Ingresa el siguiente comando de SQL para crear una ranura de replicación:

    SELECT PG_CREATE_LOGICAL_REPLICATION_SLOT('REPLICATION_SLOT_NAME', 'pgoutput');

    Reemplaza lo siguiente:

    • REPLICATION_SLOT_NAME: Es el nombre de la ranura de replicación. Deberás proporcionar este nombre cuando crees una transmisión en el asistente de creación de flujos de Datastream.

Crea un usuario de Datastream

  1. Conéctate a la base de datos con un cliente PostgreSQL.

  2. Ingresa el siguiente comando de PostgreSQL:

    CREATE USER USER_NAME WITH REPLICATION LOGIN PASSWORD 'USER_PASSWORD';

    Reemplaza lo siguiente:

    • USER_NAME: Es el nombre del usuario de Datastream que deseas crear.
    • USER_PASSWORD: La contraseña de acceso del usuario de Datastream que deseas crear.
  3. Otorga los siguientes privilegios al usuario que creaste:

    GRANT SELECT ON ALL TABLES IN SCHEMA SCHEMA_NAME TO USER_NAME;
    GRANT USAGE ON SCHEMA SCHEMA_NAME TO USER_NAME;
    ALTER DEFAULT PRIVILEGES IN SCHEMA SCHEMA_NAME
        GRANT SELECT ON TABLES TO USER_NAME;
    

    Reemplaza lo siguiente:

    • SCHEMA_NAME: Es el nombre del esquema al que deseas otorgar los privilegios.
    • USER_NAME: El usuario al que deseas otorgar los privilegios.