Tutoriel : effectuer une migration de PostgreSQL vers Azure Database pour PostgreSQL en ligne en tirant parti de DMS (classique) via l’interface Azure CLI

Vous pouvez utiliser Azure Database Migration Service pour migrer les bases de données d’une instance PostgreSQL locale vers Azure Database pour PostgreSQL avec un temps d’arrêt minimal. En d’autres termes, la migration peut être effectuée avec un temps d’arrêt minimal de l’application. Dans ce tutoriel, vous allez migrer l’exemple de base de données DVD Rental à partir d’une instance PostgreSQL 9.6 locale vers Azure Database pour PostgreSQL à l’aide de l’activité de migration en ligne dans Azure Database Migration Service.

Dans ce tutoriel, vous allez apprendre à :

  • Migrez l’exemple de schéma à l’aide de l’utilitaire pg_dump.
  • Créer une instance Azure Database Migration Service.
  • Créer un projet de migration en utilisant Azure Database Migration Service.
  • Exécuter la migration.
  • Surveiller la migration.

Notes

L’utilisation d’Azure Database Migration Service pour effectuer une migration en ligne nécessite la création d’une instance basée sur le niveau tarifaire Premium. Nous chiffrons le disque pour empêcher le vol de données pendant le processus de migration.

Important

Pour une expérience de migration optimale, Microsoft recommande de créer une instance Azure Database Migration Service dans la même région Azure que la base de données cible. Le déplacement des données entre les régions ou les zones géographiques peut ralentir le processus de migration et introduire des erreurs.

Prérequis

Pour suivre ce didacticiel, vous devez effectuer les opérations suivantes :

  • Téléchargez et installez PostgreSQL Community Edition 9.4, 9.5, 9.6 ou 10. La version du serveur PostgreSQL source doit être 9.4, 9.5, 9.6, 10, 11, 12 ou 13. (pour plus d’informations, consultez la page Versions prises en charge des bases de données PostgreSQL) ;

    Notez également que la version cible d'Azure Database pour PostgreSQL doit être égale ou ultérieure à la version PostgreSQL locale. Par exemple, PostgreSQL 9.6 peut migrer uniquement vers Azure Database pour PostgreSQL 9.6, 10 ou 11, et non vers Azure Database pour PostgreSQL 9.5.

  • Créez une instance dans Azure Database pour PostgreSQL ou créez un serveur Azure Database pour PostgreSQL - Hyperscale (Citus).

  • Créez un Réseau virtuel Microsoft Azure pour Azure Database Migration Service à l’aide du modèle de déploiement Azure Resource Manager, qui fournit une connectivité site à site à vos serveurs sources locaux via ExpressRoute ou un VPN. Pour plus d’informations sur la création d’un réseau virtuel, consultez la documentation sur le réseau virtuel, en particulier les articles sur le démarrage rapide, qui fournissent des informations pas à pas.

    Notes

    Pendant la configuration du réseau virtuel, si vous utilisez ExpressRoute avec le peering réseau à Microsoft, ajoutez ces points de terminaison au sous-réseau où doit être provisionné le service :

    • Point de terminaison de base de données cible (par exemple, un point de terminaison SQL, un point de terminaison Azure Cosmos DB, etc.)
    • Point de terminaison de stockage
    • Point de terminaison Service Bus

    Cette configuration est nécessaire car Azure Database Migration Service ne dispose pas d’une connectivité Internet.

  • Vérifiez que les règles de groupe de sécurité réseau (NSG) de votre réseau virtuel ne bloquent pas le port de sortie 443 de ServiceTag pour ServiceBus, Storage et AzureMonitor. Pour plus d’informations sur le filtrage du trafic de groupe de sécurité réseau de réseau virtuel, consultez l’article Filtrer le trafic avec les groupes de sécurité réseau.

  • Configurez votre pare-feu Windows pour accéder au moteur de base de données.

  • Ouvrez votre pare-feu Windows pour permettre à Azure Database Migration Service d’accéder au serveur PostgreSQL source, par défaut le port TCP 5432.

  • Lorsque vous utilisez une appliance de pare-feu devant vos bases de données sources, vous devrez peut-être ajouter des règles de pare-feu pour permettre à Azure Database Migration Service d’accéder aux bases de données sources pour la migration.

  • Créez une règle de pare-feu de niveau serveur pour Azure Database pour PostgreSQL afin de permettre à Azure Database Migration Service d’accéder aux bases de données cibles. Fournissez la plage de sous-réseau du réseau virtuel utilisé pour Azure Database Migration Service.

  • Il existe deux méthodes pour appeler l’interface CLI :

    • Dans l’angle supérieur droit du portail Azure, sélectionnez le bouton Cloud Shell :

      Bouton Cloud Shell du portail Azure

    • Installez et exécutez l’interface CLI localement. L’interface CLI 2,18 ou version ultérieure de l’outil en ligne de commande est nécessaire pour gérer les ressources Azure nécessaires à cette migration.

      Pour télécharger l’interface CLI, suivez les instructions fournies dans l’article Installer Azure CLI. Cet article répertorie également les plateformes qui prennent en charge Azure CLI.

      Pour configurer Sous-système Windows pour Linux (WSL), suivez les instructions du Guide d’installation de Windows 10

  • Activez la réplication logique sur le serveur source, en modifiant le fichier postgresql.config et en définissant les paramètres suivants :

    • wal_level = logical
    • max_replication_slots = [nombre d’emplacements]. Valeur recommandée : cinq emplacements
    • max_wal_senders = [nombre de tâches simultanées] - le paramètre max_wal_senders définit le nombre de tâches simultanées qui peuvent s’exécuter, paramètre recommandé : 10 tâches

Migrer l’exemple de schéma

Pour compléter tous les objets de base de données tels que les schémas de table, les index et les procédures stockées, nous devons extraire le schéma à partir de la base de données source et l’appliquer à la base de données.

  1. Utilisez la commande pg_dump -s afin de créer un fichier de vidage de schéma pour une base de données.

    pg_dump -O -h hostname -U db_username -d db_name -s > your_schema.sql
    

    Par exemple, pour vider un fichier de schéma d’une base de données dvdrental :

    pg_dump -O -h localhost -U postgres -d dvdrental -s  > dvdrentalSchema.sql
    

    Pour plus d’informations sur l’utilisation de l’utilitaire pg_dump, consultez les exemples du tutoriel pg-dump.

  2. Créez une base de données vide dans votre environnement cible, c’est-à-dire Azure Database pour PostgreSQL.

    Pour plus d’informations sur la création et la connexion d’une base de données, consultez Créer un serveur Azure Database pour PostgreSQL dans le portail Azure ou Créer un serveur Azure Database pour PostgreSQL - Hyperscale (Citus) dans le portail Azure.

  3. Importez le schéma dans la base de données cible que vous avez créée en restaurant le fichier de vidage du schéma.

    psql -h hostname -U db_username -d db_name < your_schema.sql 
    

    Par exemple :

    psql -h mypgserver-20170401.postgres.database.azure.com  -U postgres -d dvdrental < dvdrentalSchema.sql
    

Notes

Le service de migration gère en interne l’activation et la désactivation des clés et des déclencheurs étrangers pour garantir une migration fiable des données. Par conséquent, vous n’avez pas à vous soucier d’apporter des modifications au schéma de la base de données cible.

Provisionnement d’une instance de DMS à l’aide de l’interface Azure CLI

  1. Installez l’extension de synchronisation dms :

    • Connectez-vous à Azure en exécutant la commande suivante :

      az login
      
    • Lorsque vous y êtes invité, ouvrez un navigateur web et entrez un code pour authentifier votre appareil. Suivez les instructions indiquées.

    • La migration en ligne PostgreSQL est désormais disponible dans le package CLI standard (version 2.18.0 et versions ultérieures) sans avoir besoin de l'extension dms-preview. Si vous avez installé l’extension par le passé, vous pouvez la supprimer en procédant comme suit :

      • Pour vérifier si l’extension dms-preview est déjà installée, exécutez la commande suivante :

        az extension list -o table
        
      • Si l’extension dms-preview est installée, pour la désinstaller, exécutez la commande suivante :

        az extension remove --name dms-preview
        
      • Pour vérifier que vous avez correctement désinstallé l'extension dms-preview, exécutez la commande suivante et vous ne devriez pas voir l’extension dms-preview dans la liste :

        az extension list -o table
        

      Important

      L’extension dms-preview peut toujours être nécessaire pour d’autres chemins de migration pris en charge par Azure DMS. Consultez la documentation du chemin de migration spécifique pour déterminer si l’extension est nécessaire. Cette documentation traite de l’exigence de l’extension, propre à PostgreSQL dans Azure Database pour PostgreSQL Online.

    • À tout moment, affichez toutes les commandes prises en charge dans DMS en exécutant :

      az dms -h
      
    • Si vous avez plusieurs abonnements Azure, exécutez la commande suivante pour sélectionner l’abonnement avec lequel vous souhaitez travailler.

      az account set -s 97181df2-909d-420b-ab93-1bff15acb6b7
      
  2. Approvisionnez une instance DMS en exécutant la commande suivante :

    az dms create -l <location> -n <newServiceName> -g <yourResourceGroupName> --sku-name Premium_4vCores --subnet/subscriptions/{vnet subscription id}/resourceGroups/{vnet resource group}/providers/Microsoft.Network/virtualNetworks/{vnet name}/subnets/{subnet name} –tags tagName1=tagValue1 tagWithNoValue
    

    Par exemple, la commande suivante crée un service dans :

    • Localisation : USA Est 2
    • Abonnement : 97181df2-909d-420b-ab93-1bff15acb6b7
    • Nom du groupe de ressources : PostgresDemo
    • Nom du service DMS : PostgresCLI
    az dms create -l eastus2 -g PostgresDemo -n PostgresCLI --subnet /subscriptions/97181df2-909d-420b-ab93-1bff15acb6b7/resourceGroups/ERNetwork/providers/Microsoft.Network/virtualNetworks/AzureDMS-CORP-USC-VNET-5044/subnets/Subnet-1 --sku-name Premium_4vCores
    

    La création de l’instance du service DMS prend 10 à 12 minutes.

  3. Pour identifier l’adresse IP de l’agent DMS afin de l’ajouter au fichier pg_hba.conf Postgres, exécutez la commande suivante :

    az network nic list -g <ResourceGroupName>--query '[].ipConfigurations | [].privateIpAddress'
    

    Par exemple :

    az network nic list -g PostgresDemo --query '[].ipConfigurations | [].privateIpAddress'
    

    Vous devriez voir un résultat similaire à celui de l’écran suivant :

    [
      "172.16.136.18"
    ]
    
  4. Ajoutez l’adresse IP de l’agent DMS au fichier Postgres pg_hba.conf.

    • Notez l’adresse IP DMS après avoir terminé l’approvisionnement dans DMS.

    • Ajoutez l’adresse IP au fichier pg_hba.conf sur la source, comme dans l’entrée suivante :

      host     all            all        172.16.136.18/10    md5
      host     replication    postgres   172.16.136.18/10    md5
      
  5. Ensuite, créez un projet de migration PostgreSQL en exécutant la commande suivante :

    az dms project create -l <location> -g <ResourceGroupName> --service-name <yourServiceName> --source-platform PostgreSQL --target-platform AzureDbforPostgreSQL -n <newProjectName>
    

    Par exemple, la commande suivante crée un projet à l’aide de ces paramètres :

    • Localisation : Centre-USA Ouest
    • Nom du groupe de ressources : PostgresDemo
    • Nom du service : PostgresCLI
    • Nom du projet : PGMigration
    • Plateforme source : PostgreSQL
    • Plateforme cible : AzureDbForPostgreSql
    az dms project create -l westcentralus -n PGMigration -g PostgresDemo --service-name PostgresCLI --source-platform PostgreSQL --target-platform AzureDbForPostgreSql
    
  6. Créez une tâche de migration PostgreSQL en procédant comme suit.

    Cette étape inclut l’utilisation de l’adresse IP source, de l’ID utilisateur et du mot de passe, de l’adresse IP de destination, de l’ID utilisateur, du mot de passe et du type de tâche pour établir la connectivité.

    • Pour afficher une liste complète des options, exécutez la commande :

      az dms project task create -h
      

      Pour les connexions source et cible, le paramètre d’entrée fait référence à un fichier json qui contient la liste des objets.

      Le format de l’objet JSON de connexion pour les connexions PostgreSQL.

      {
          // if this is missing or null, you will be prompted
          "userName": "user name",
          // if this is missing or null (highly recommended) you will  be prompted  
          "password": null,
          "serverName": "server name",
          // if this is missing, it will default to the 'postgres' database
          "databaseName": "database name",
          // if this is missing, it will default to 5432 
          "port": 5432                
      }
      

      Il existe également un fichier json des options de base de données, qui répertorie les objets json. Pour PostgreSQL, le format de l’objet JSON des options de base de données est indiqué ci-dessous :

      [
          {
              "name": "source database",
              "target_database_name": "target database",
              "selectedTables": [
                  "schemaName1.tableName1",
                  ...n
              ]
          },
          ...n
      ]
      
    • Pour créer le json de connexion source, ouvrez Bloc-notes et copiez le fichier json suivant et collez-le dans le fichier. Enregistrez le fichier dans C:\DMS\source.json après l’avoir modifié en fonction de votre serveur source.

      {
          "userName": "postgres",    
          "password": null,
          "serverName": "13.51.14.222",
          "databaseName": "dvdrental", 
          "port": 5432                
      }
      
    • Pour créer le json de connexion cible, ouvrez Bloc-notes et copiez le fichier json suivant et collez-le dans le fichier. Enregistrez le fichier dans C:\DMS\target.json après l’avoir modifié en fonction de votre serveur cible.

      {
          "userName": " dms@builddemotarget",    
          "password": null,           
          "serverName": " builddemotarget.postgres.database.azure.com",
          "databaseName": "inventory", 
          "port": 5432                
      }
      
    • Créez un fichier json d’options de base de données qui répertorie un inventaire et un mappage de la base de données à migrer :

      • Créer une liste de tables à migrer, ou vous pouvez utiliser une requête de SQL pour générer la liste à partir de la base de données source. Vous trouverez ci-dessous un exemple de requête permettant de générer la liste des tables. Si vous utilisez cette requête, n’oubliez pas de supprimer la dernière virgule à la fin du nom de la dernière table pour en faire un tableau JSON valide.

        SELECT
            FORMAT('%s,', REPLACE(FORMAT('%I.%I', schemaname, tablename), '"', '\"')) AS SelectedTables
        FROM 
            pg_tables
        WHERE 
            schemaname NOT IN ('pg_catalog', 'information_schema');
        
      • Créez le fichier JSON des options de base de données avec une entrée pour chaque base de données avec les noms des bases de données source et cible, ainsi que la liste des tables sélectionnées à migrer. vous pouvez utiliser la sortie de la requête SQL ci-dessus pour remplir le tableau « selectedTables » . Notez que si la liste des tables sélectionnées est vide, le service inclut toutes les tables pour la migration qui ont des noms de schéma et de table correspondants.

        [
            {
                "name": "dvdrental",
                "target_database_name": "dvdrental",
                "selectedTables": [
                    "schemaName1.tableName1",
                    "schemaName1.tableName2",                    
                    ...
                    "schemaNameN.tableNameM"
                ]
            },
            ... n
        ]
        
    • Exécutez la commande suivante, qui prend en compte la connexion source, la connexion cible et les fichiers json d'options de base de données.

      az dms project task create -g PostgresDemo --project-name PGMigration --source-connection-json c:\DMS\source.json --database-options-json C:\DMS\option.json --service-name PostgresCLI --target-connection-json c:\DMS\target.json --task-type OnlineMigration -n runnowtask    
      

    À ce stade, vous avez correctement envoyé une tâche de migration.

  7. Pour afficher la progression de la tâche, exécutez la commande suivante :

    • Pour afficher l’état général des tâches en abrégé

      az dms project task show --service-name PostgresCLI --project-name PGMigration --resource-group PostgresDemo --name runnowtask
      
    • Pour afficher l’état détaillé de la tâche, y compris les informations de progression de la migration

      az dms project task show --service-name PostgresCLI --project-name PGMigration --resource-group PostgresDemo --name runnowtask --expand output
      
    • Vous pouvez également utiliser le format de requête JMESPath pour extraire uniquement les migrationState de la sortie de développement :

      az dms project task show --service-name PostgresCLI --project-name PGMigration --resource-group PostgresDemo --name runnowtask --expand output --query 'properties.output[].migrationState'
      

      Dans la sortie, plusieurs paramètres indiquent la progression des étapes de migration. Par exemple, consultez la sortie ci-dessous :

      {
          "output": [
              // Database Level
              {
                  "appliedChanges": 0, // Total incremental sync applied after full load
                  "cdcDeleteCounter": 0, // Total delete operation  applied after full load
                  "cdcInsertCounter": 0, // Total insert operation applied after full load
                  "cdcUpdateCounter": 0, // Total update operation applied after full load
                  "databaseName": "inventory",
                  "endedOn": null,
                  "fullLoadCompletedTables": 2, //Number of tables completed full load
                  "fullLoadErroredTables": 0, //Number of tables that contain migration error
                  "fullLoadLoadingTables": 0, //Number of tables that are in loading status
                  "fullLoadQueuedTables": 0, //Number of tables that are in queued status
                  "id": "db|inventory",
                  "incomingChanges": 0, //Number of changes after full load
                  "initializationCompleted": true,
                  "latency": 0,
                  //Status of migration task
                  "migrationState": "READY_TO_COMPLETE", //READY_TO_COMPLETE => the database is ready for cutover
                  "resultType": "DatabaseLevelOutput",
                  "startedOn": "2018-07-05T23:36:02.27839+00:00"
              }, {
                  "databaseCount": 1,
                  "endedOn": null,
                  "id": "dd27aa3a-ed71-4bff-ab34-77db4261101c",
                  "resultType": "MigrationLevelOutput",
                  "sourceServer": "138.91.123.10",
                  "sourceVersion": "PostgreSQL",
                  "startedOn": "2018-07-05T23:36:02.27839+00:00",
                  "state": "PENDING",
                  "targetServer": "builddemotarget.postgres.database.azure.com",
                  "targetVersion": "Azure Database for PostgreSQL"
              },
              // Table 1
              {
                  "cdcDeleteCounter": 0,
                  "cdcInsertCounter": 0,
                  "cdcUpdateCounter": 0,
                  "dataErrorsCount": 0,
                  "databaseName": "inventory",
                  "fullLoadEndedOn": "2018-07-05T23:36:20.740701+00:00", //Full load completed time
                  "fullLoadEstFinishTime": "1970-01-01T00:00:00+00:00",
                  "fullLoadStartedOn": "2018-07-05T23:36:15.864552+00:00", //Full load started time
                  "fullLoadTotalRows": 10, //Number of rows loaded in full load
                  "fullLoadTotalVolumeBytes": 7056, //Volume in Bytes in full load
                  "id": "or|inventory|public|actor",
                  "lastModifiedTime": "2018-07-05T23:36:16.880174+00:00",
                  "resultType": "TableLevelOutput",
                  "state": "COMPLETED", //State of migration for this table
                  "tableName": "public.catalog", //Table name
                  "totalChangesApplied": 0 //Total sync changes that applied after full load
              },
              //Table 2
              {
                  "cdcDeleteCounter": 0,
                  "cdcInsertCounter": 50,
                  "cdcUpdateCounter": 0,
                  "dataErrorsCount": 0,
                  "databaseName": "inventory",
                  "fullLoadEndedOn": "2018-07-05T23:36:23.963138+00:00",
                  "fullLoadEstFinishTime": "1970-01-01T00:00:00+00:00",
                  "fullLoadStartedOn": "2018-07-05T23:36:19.302013+00:00",
                  "fullLoadTotalRows": 112,
                  "fullLoadTotalVolumeBytes": 46592,
                  "id": "or|inventory|public|address",
                  "lastModifiedTime": "2018-07-05T23:36:20.308646+00:00",
                  "resultType": "TableLevelOutput",
                  "state": "COMPLETED",
                  "tableName": "public.orders",
                  "totalChangesApplied": 0
              }
          ],
          // DMS migration task state
          "state": "Running", //Running => service is still listening to any changes that might come in
          "taskType": null
      }
      

Tâche de migration de basculement

La base de données est prête pour le basculement lorsque le chargement est terminé. Selon la charge du serveur source qui traite les nouvelles transactions entrantes, la tâche DMS applique peut-être toujours les modifications après que le chargement complet.

Pour garantir la récupération de toutes les données, validez le nombre de lignes entre les bases de données source et cible. Par exemple, vous pouvez valider les détails suivants à partir de la sortie de l’état :

Database Level
"migrationState": "READY_TO_COMPLETE" => Status of migration task. READY_TO_COMPLETE means database is ready for cutover
"incomingChanges": 0 => Check for a period of 5-10 minutes to ensure no new incoming changes need to be applied to the target server

Table Level (for each table)
"fullLoadTotalRows": 10    => The row count matches the initial row count of the table
"cdcDeleteCounter": 0      => Number of deletes after the full load
"cdcInsertCounter": 50     => Number of inserts after the full load
"cdcUpdateCounter": 0      => Number of updates after the full load
  1. Effectuez la tâche de migration de base de données de basculement à l’aide de la commande suivante :

    az dms project task cutover -h
    

    Par exemple, la commande suivante initie le basculement pour la base de données « Inventory » :

    az dms project task cutover --service-name PostgresCLI --project-name PGMigration --resource-group PostgresDemo --name runnowtask  --object-name Inventory
    
  2. Pour surveiller la progression du basculement, exécutez la commande suivante :

    az dms project task show --service-name PostgresCLI --project-name PGMigration --resource-group PostgresDemo --name runnowtask
    
  3. Lorsque l’état de migration de la base de données indique Terminé, recréez des séquences (le cas échéant) et connectez vos applications à la nouvelle instance cible d’Azure Database pour PostgreSQL.

Nettoyage d’un service, d’un projet ou d’une tâche

Si vous avez besoin d’annuler ou de supprimer une tâche, un projet ou un service DMS, effectuez l’annulation dans selon la séquence suivante :

  • Annuler toutes les tâches en cours d'exécution
  • Supprimez la tâche
  • Supprimez le projet
  • Créez un service DMS
  1. Pour annuler une tâche en cours d’exécution, utilisez la commande suivante :

    az dms project task cancel --service-name PostgresCLI --project-name PGMigration --resource-group PostgresDemo --name runnowtask
    
  2. Pour supprimer une tâche en cours d’exécution, utilisez la commande suivante :

    az dms project task delete --service-name PostgresCLI --project-name PGMigration --resource-group PostgresDemo --name runnowtask
    
  3. Pour supprimer un projet, utilisez la commande suivante :

    az dms project delete -n PGMigration -g PostgresDemo --service-name PostgresCLI
    
  4. Pour supprimer un service DMS, utilisez la commande suivante :

    az dms delete -g ProgresDemo -n PostgresCLI
    

Étapes suivantes