Configurer une base de données Cloud SQL pour PostgreSQL

Les sections suivantes expliquent comment configurer une base de données Cloud SQL pour PostgreSQL.

Activer la réplication logique

  1. Accédez à Cloud SQL dans la console Google Cloud.

  2. Ouvrez l'instance Cloud SQL et cliquez sur MODIFIER.

  3. Accédez à la section Options.

  4. Cliquez sur AJOUTER UNE OPTION.

  5. Sélectionnez l'indicateur cloudsql.logical_decoding dans le menu déroulant.

  6. Définissez la valeur de l'indicateur sur on.

  7. Cliquez sur ENREGISTRER pour enregistrer les modifications. Vous devez redémarrer votre instance pour qu'elle prenne en compte les modifications.

  8. Une fois votre instance redémarrée, confirmez vos modifications sous Options de base de données sur la page Présentation.

Créer une publication et un emplacement de réplication

  1. Connectez-vous à la base de données en tant qu'utilisateur disposant des droits suffisants pour créer un emplacement de réplication. Sinon, exécutez la commande suivante:

    ALTER USER USER_NAME WITH REPLICATION;
    

    Remplacez les éléments suivants :

    • USER_NAME: nom de l'utilisateur auquel vous souhaitez accorder des droits de réplication.
  2. Créez une publication. Nous vous recommandons de créer une publication uniquement pour les tables que vous souhaitez répliquer. Cela permet à Datastream de lire uniquement les données pertinentes, et de réduire la charge sur la base de données et Datastream:

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

    Remplacez les éléments suivants :

    • PUBLICATION_NAME: nom de votre publication. Vous devrez fournir ce nom lorsque vous créerez un flux dans l'assistant de création de flux Datastream.
    • SCHEMA: nom du schéma contenant la table.
    • TABLE: nom de la table que vous souhaitez répliquer.

    Vous pouvez créer une publication pour toutes les tables d'un schéma. Cette approche vous permet de répliquer les modifications apportées aux tables de la liste de schémas spécifiée, y compris aux tables que vous créerez par la suite:

    CREATE PUBLICATION PUBLICATION_NAME
    FOR TABLES IN SCHEMA1, SCHEMA2;

    Vous pouvez également créer une publication pour toutes les tables de votre base de données. Notez que cette approche augmente la charge sur la base de données source et sur Datastream:

    CREATE PUBLICATION PUBLICATION_NAME FOR ALL TABLES;
    
  3. Créez un emplacement de réplication en saisissant la commande SQL suivante:

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

    Remplacez les éléments suivants :

    • REPLICATION_SLOT_NAME: nom de votre emplacement de réplication. Vous devrez indiquer ce nom lorsque vous créerez un flux dans l'assistant de création de flux Datastream.

Créer un utilisateur Datastream

  1. Connectez-vous à la base de données à l'aide d'un client PostgreSQL.

  2. Saisissez la commande PostgreSQL suivante:

    CREATE USER USER_NAME WITH REPLICATION LOGIN PASSWORD 'USER_PASSWORD';

    Remplacez les éléments suivants :

    • USER_NAME: nom de l'utilisateur Datastream que vous souhaitez créer.
    • USER_PASSWORD: mot de passe de connexion de l'utilisateur Datastream que vous souhaitez créer.
  3. Accordez les droits suivants à l'utilisateur que vous avez créé :

    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;
    

    Remplacez les éléments suivants :

    • SCHEMA_NAME: nom du schéma auquel vous souhaitez accorder les droits.
    • USER_NAME: utilisateur auquel vous souhaitez accorder les droits