Configura una base de datos de PostgreSQL en Amazon RDS

En la siguiente página, se explica cómo configurar la CDC para una base de datos de Amazon RDS para PostgreSQL.

Crea un grupo de parámetros

  1. Inicia el panel de Amazon RDS.

  2. En el panel lateral de navegación, haz clic en Grupos de parámetros y, luego, en Crear grupo de parámetros. Aparecerá la página Crear grupo de parámetros.

  3. Selecciona la familia de base de datos que coincida con tu base de datos, proporciona un nombre y una descripción para el grupo de parámetros y, luego, haz clic en Crear.

  4. Selecciona la casilla de verificación que se encuentra a la izquierda del grupo de parámetros recién creado y, en Acciones del grupo de parámetros, haz clic en Editar.

  5. Establece el siguiente parámetro para tu grupo.

    ParámetroValor
    logical_replication1
  6. Haz clic en Guardar cambios.

Configura la base de datos de origen

  1. Inicia el panel de Amazon RDS.

  2. En el panel lateral de navegación, haz clic en Databases.

  3. Selecciona la fuente y haz clic en Modificar.

  4. Ve a la sección Configuración adicional.

  5. Selecciona el grupo de parámetros que creaste.

  6. Haz clic en Continuar.

  7. En Scheduling of modifications, selecciona Apply immediately.

Verifica que el grupo de parámetros esté asignado a la instancia de la base de datos

  1. Inicia el panel de Amazon RDS.

  2. En el panel lateral de navegación, haz clic en Bases de datos y, luego, selecciona tu instancia de base de datos.

  3. Haz clic en la pestaña Configurations.

  4. Verifica que veas el grupo de parámetros que creaste y que su estado sea pending-reboot.

  5. Reinicia la instancia de base de datos para completar la configuración. Para reiniciar la instancia, sigue estos pasos:

    1. En el panel lateral de navegación, haz clic en Instances.
    2. Selecciona tu instancia de base de datos.
    3. En el menú Instance Actions, selecciona Reboot.

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

  1. 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;
    
  2. Ingresa el siguiente comando de PostgreSQL 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. Para crear un usuario de Datastream, ingresa el siguiente comando de PostgreSQL:

    CREATE USER USER_NAME WITH ENCRYPTED 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.
  2. Otorga los siguientes privilegios al usuario que creaste:

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

    Reemplaza lo siguiente:

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