Partager via


Migrer Amazon RDS pour MySQL vers Azure Database pour MySQL à l’aide de la réplication des données entrantes

Remarque

Cet article contient des références au terme esclave, un terme que Microsoft n’utilise plus. Lorsque le terme sera supprimé du logiciel, nous le supprimerons de cet article.

Vous pouvez utiliser des méthodes telles que le vidage et la restauration MySQL, l’exportation et l’importation MySQL Workbench ou Azure Database Migration Service pour migrer vos bases de données MySQL vers Azure Database pour MySQL – Serveur flexible. Vous pouvez migrer vos charges de travail avec un temps d’arrêt minimal en utilisant une combinaison d’outils open source tels que mysqldump ou mydumper et myloader avec Réplication des données entrantes.

Réplication des données entrantes est une technique qui réplique les modifications de données du serveur source vers le serveur de destination en fonction de la méthode de position de fichier journal binaire. Dans ce scénario, l’instance MySQL opérant en tant que source (sur laquelle les modifications sont apportées à la base de données) écrit les mises à jour et les modifications en tant qu’événements dans le journal binaire. Les informations contenues dans le journal binaire sont stockées dans différents formats de journalisation en fonction des modifications de la base de données en cours d’enregistrement. Les réplicas sont configurés pour lire le journal binaire à partir de la source et pour exécuter les événements du journal binaire sur la base de données locale du réplica.

Configurez Répliquer des données dans Azure Database pour MySQL : serveur flexible pour synchroniser les données d’un serveur MySQL source vers un serveur MySQL cible. Vous pouvez effectuer un basculement sélectif de vos applications à partir des données primaires (ou base de données source) vers le réplica (ou base de données cible).

Dans ce tutoriel, vous apprendrez à configurer Réplication des données entrantes entre un serveur source qui exécute Amazon Relational Database Service (RDS) pour MySQL et un serveur cible qui exécute Azure Database pour MySQL – Serveur flexible.

Considérations relatives aux performances

Avant de commencer ce tutoriel, tenez compte des répercussions sur les performances de l’emplacement et de la capacité de l’ordinateur client que vous allez utiliser pour effectuer l’opération.

Emplacement du client

Effectuez des opérations de sauvegarde ou de restauration à partir d’un ordinateur client qui est lancé dans le même emplacement que le serveur de base de données :

  • Pour les instances d’Azure Database pour MySQL – Serveur flexible, l’ordinateur client doit se trouver dans le même réseau virtuel et dans la même zone de disponibilité que le serveur de base de données cible.
  • Pour les instances de base de données Amazon RDS sources, l’instance cliente doit exister dans le même cloud Amazon Virtual Private Cloud et dans la même zone de disponibilité que le serveur de base de données source. Dans le cas précédent, vous pouvez déplacer les copies de sauvegarde entre des ordinateurs clients à l’aide de protocoles de transfert de fichiers tels que FTP ou SFTP ou les charger vers Stockage Blob Azure. Pour réduire la durée totale de la migration, compressez les fichiers avant de les transférer.

Capacité du client

Quel que soit l’emplacement de l’ordinateur client, celui-ci requiert des capacités de calcul, d’E/S et réseau adéquates pour effectuer les opérations demandées. Les recommandations générales sont les suivantes :

  • Si la sauvegarde ou la restauration implique le traitement en temps réel des données, par exemple la compression ou la décompression, choisissez une classe d’instance avec au moins un cœur de processeur par thread de vidage ou de restauration.
  • Assurez-vous que l’instance cliente dispose d’une bande passante réseau suffisante. Utilisez des types d’instance qui prennent en charge la fonctionnalité de performances réseau accélérées. Pour plus d’informations, consultez la section « Performances réseau accélérées » dans le guide de mise en réseau de machines virtuelles Azure.
  • Assurez-vous que la couche de stockage de l’ordinateur client offre la capacité de lecture/écriture attendue. Nous vous recommandons d’utiliser une machine virtuelle Azure avec un stockage SSD Premium.

Prérequis

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

  • Installez mysqlclient sur votre ordinateur client pour créer une copie de sauvegarde, et effectuez une opération de restauration sur votre instance d’Azure Database pour MySQL – Serveur flexible.

  • Pour les bases de données plus volumineuses, installez mydumper et myloader pour effectuer des sauvegardes et des restaurations parallèles des bases de données.

    Notes

    Mydumper ne peut fonctionner que sur les distributions Linux. Pour plus d’informations, consultez Comment installer mydumper.

  • Créez une instance d’Azure Database pour MySQL – Serveur flexible qui exécute la version 5.7 ou 8.0.

    Important

    Si votre cible est un serveur flexible Azure Database pour MySQL avec une haute disponibilité redondante interzone, notez que Réplication des données entrantes n’est pas prise en charge pour cette configuration. Pour une solution de contournement, lors de la création du serveur, configurez la haute disponibilité redondante interzone :

    1. Créez le serveur avec la haute disponibilité redondante interzone.
    2. Désactivez la haute disponibilité.
    3. Suivez l’article pour configurer Réplication des données entrantes.
    4. Après le basculement, supprimez la configuration de Réplication des données entrantes.
    5. Activez la haute disponibilité.

Assurez-vous que plusieurs paramètres et fonctionnalités sont configurés et configurés correctement, comme décrit :

  • Pour des raisons de compatibilité, ayez les serveurs de base de données source et cible sur la même version de MySQL.
  • Avoir une clé primaire dans chaque table. L’absence de clés primaires sur les tables peut ralentir le processus de réplication.
  • Assurez-vous que le jeu de caractères des bases de données source et cible est identique.
  • Définissez le paramètre wait_timeout sur un délai raisonnable. Ce délai dépend de la quantité de données ou de la charge de travail que vous souhaitez importer ou migrer.
  • Vérifiez que toutes vos tables utilisent InnoDB. Azure Database pour MySQL – Serveur flexible ne prend en charge que le moteur de stockage InnoDB.
  • Pour les tables comportant de nombreux index secondaires ou pour les tables volumineuses, les effets de la surcharge des performances sont visibles pendant la restauration. Modifiez les copies de sauvegarde afin que les instructions CREATE TABLE n’incluent pas les définitions de clé secondaires. Après avoir importé les données, recréez les index secondaires pour éviter de pénaliser les performances pendant le processus de restauration.

Enfin, pour préparer Réplication des données entrantes :

  • Vérifiez que l’instance cible d’Azure Database pour MySQL – Serveur flexible peut se connecter au serveur Amazon RDS pour MySQL sur le port 3306.
  • Assurez-vous que le serveur source Amazon RDS pour MySQL autorise le trafic entrant et sortant sur le port 3306.
  • Assurez-vous de fournir une connectivité site à site à votre serveur source en utilisant Azure ExpressRoute ou une passerelle VPN Azure. Pour plus d’informations sur la création d’un réseau virtuel, consultez la documentation de Réseau virtuel Azure. Consultez également les articles de démarrage rapide contenant des détails étape par étape.
  • Configurez les groupes de sécurité réseau de votre serveur de base de données source de façon à autoriser l’adresse IP cible d’Azure Database pour MySQL – Serveur flexible.

Important

Si l’instance source d’Amazon RDS pour MySQL a GTID_mode défini sur ON, l’instance cible d’Azure Database for MySQL – Serveur flexible doit également avoir GTID_mode défini sur ON.

Configurer l’instance cible Azure Database pour MySQL

Pour configurer l’instance cible d’Azure Database pour MySQL – Serveur flexible, qui est la cible de Réplication des données entrantes :

  1. Définissez la valeur du paramètre max_allowed_packet au maximum de 1073741824, soit 1 Go. Cette valeur permet d’éviter tout problème de dépassement lié aux longues lignes.

  2. Définissez les paramètres slow_query_log, general_log, audit_log_enabled et query_store_capture_mode sur OFF pendant la migration afin d’éliminer toute surcharge liée à la journalisation des requêtes.

  3. Effectuez un scale-up de la taille de calcul de l’instance cible d’Azure Database pour MySQL – Serveur flexible jusqu’à un maximum de 64 vCores. Cette taille fournit davantage de ressources de calcul lors de la restauration de la copie de sauvegarde de la base de données du serveur source.

    Vous pouvez toujours mettre à l’échelle le calcul pour répondre aux demandes de votre application une fois la migration terminée.

  4. Augmentez la taille du stockage pour obtenir plus d’E/S par seconde pendant la migration ou augmentez le nombre maximal d’E/S par seconde pour la migration.

    Notes

    Le nombre maximal d’IOPS disponibles est déterminé par la taille de calcul. Pour plus d’informations, consultez la section IOPS dans Options de calcul et de stockage dans Azure Database pour MySQL – Serveur flexible.

Configurer la source Amazon RDS pour MySQL Server

Pour préparer et configurer le serveur MySQL hébergé dans Amazon RDS, qui est la source dans Réplication des données entrantes :

  1. Vérifiez que la journalisation binaire est activée sur le serveur Amazon RDS pour MySQL source. Vérifiez que les sauvegardes automatiques sont activées, ou assurez-vous qu’un réplica en lecture existe pour le serveur Amazon RDS pour MySQL source.

  2. Vérifiez que les fichiers journaux binaires sur le serveur source sont conservés jusqu’à ce que les modifications soient appliquées sur l’instance cible d’Azure Database pour MySQL – Serveur flexible.

    Avec Réplication des données entrantes, Azure Database pour MySQL – Serveur flexible ne gère pas le processus de réplication.

  3. Pour vérifier la rétention des journaux binaires sur le serveur Amazon RDS source afin de déterminer le nombre d’heures pendant lesquelles les journaux binaires sont conservés, appelez la procédure stockée mysql.rds_show_configuration :

    call mysql.rds_show_configuration;
    +------------------------+-------+-----------------------------------------------------------------------------------------------------------+
    | name | value | description |
    | +------------------------+-------+-----------------------------------------------------------------------------------------------------------+ |
    | binlog retention hours | 24 | binlog retention hours specifies the duration in hours before binary logs are automatically deleted. |
    | source delay | 0 | source delay specifies replication delay in seconds between current instance and its master. |
    | target delay | 0 | target delay specifies replication delay in seconds between current instance and its future read-replica. |
    | +------------------------+------- +-----------------------------------------------------------------------------------------------------------+ |
    | 3 rows in set (0.00 sec) |
    
  4. Pour configurer la période de rétention des journaux binaires, exécutez la procédure stockée rds_set_configuration pour vous assurer que les journaux binaires sont conservés sur le serveur source pendant la durée souhaitée. Par exemple :

    Call mysql.rds_set_configuration('binlog retention hours', 96);
    

    Si vous créez une copie de sauvegarde, puis effectuez une restauration, la commande précédente vous aide à rattraper rapidement les modifications delta.

    Notes

    Assurez-vous qu’il y a suffisamment d’espace disque pour stocker les journaux binaires sur le serveur source en fonction de la période de rétention définie.

Il existe deux façons de capturer une copie de sauvegarde des données à partir du serveur Amazon RDS pour MySQL source. La première approche consiste à capturer une copie de sauvegarde des données directement à partir du serveur source. L’autre approche consiste à capturer une copie de sauvegarde à partir d’un réplica en lecture Amazon RDS pour MySQL.

  • Pour capturer une copie de sauvegarde des données directement à partir du serveur source :

    1. Veillez à arrêter les écritures de l’application pendant quelques minutes pour obtenir une copie de sauvegarde des données cohérente du point de vue transactionnel.

      Vous pouvez également affecter temporairement la valeur 1 au paramètre read_only afin que les écritures ne soient pas traitées lorsque vous capturez une copie de sauvegarde des données.

    2. Après avoir arrêté les écritures sur le serveur source, récupérez le nom et le décalage du fichier journal binaire en exécutant la commande Mysql> Show master status;.

    3. Enregistrez ces valeurs pour démarrer la réplication à partir de votre instance d’Azure Database pour MySQL – Serveur flexible.

    4. Pour créer une copie de sauvegarde des données, exécutez mysqldump à l’aide de la commande suivante :

      $ mysqldump -h hostname -u username -p –single-transaction –databases dbnames –order-by-primary> dumpname.sql
      
  • Si l’arrêt des écritures sur le serveur source n’est pas une option ou si les performances de la sauvegarde des données ne sont pas acceptables sur le serveur source, capturez une copie de sauvegarde sur un serveur réplica :

    1. Créez un réplica en lecture Amazon MySQL avec la même configuration que le serveur source. Ensuite, créez la copie de sauvegarde dans ce réplica.

    2. Laissez le réplica de lecture Amazon RDS pour MySQL rattraper le serveur Amazon RDS pour MySQL source.

    3. Lorsque le décalage du réplica atteint 0 sur le réplica en lecture, arrêtez la réplication en appelant la procédure stockée mysql.rds_stop_replication.

      call mysql.rds_stop_replication;
      
    4. Une fois la réplication arrêtée, connectez-vous au réplica. Exécutez ensuite la commande SHOW SLAVE STATUS pour récupérer le nom actuel du fichier journal binaire dans le champ Relay_Master_Log_File et la position du fichier journal à partir du champ Exec_Master_Log_Pos.

    5. Enregistrez ces valeurs pour démarrer la réplication à partir de votre instance d’Azure Database pour MySQL – Serveur flexible.

    6. Pour créer une copie de sauvegarde des données à partir du réplica en lecture Amazon RDS pour MySQL, exécutez mysqldump à l’aide de la commande suivante :

      $ mysqldump -h hostname -u username -p –single-transaction –databases dbnames –order-by-primary> dumpname.sql
      

    Notes

    Vous pouvez également utiliser mydumper pour capturer une copie de sauvegarde mise en parallèle de vos données à partir de votre base de données Amazon RDS pour MySQL source. Pour plus d’informations, consultez Migrer des bases de données volumineuses vers Azure Database pour MySQL – Serveur flexible avec mydumper/myloader.

  1. Pour restaurer la base de données à l’aide de la restauration native MySQL, exécutez la commande suivante :

    $ mysql -h <target_server> -u <targetuser> -p < dumpname.sql
    
  2. Connectez-vous au serveur Amazon RDS pour MySQL source et configurez un utilisateur de réplication. Accordez ensuite les privilèges nécessaires à cet utilisateur.

    • Si vous utilisez SSL, exécutez les commandes suivantes :

      CREATE USER 'syncuser'@'%' IDENTIFIED BY 'userpassword';
      GRANT REPLICATION SLAVE, REPLICATION CLIENT on *.* to 'syncuser'@'%' REQUIRE SSL;
      SHOW GRANTS FOR syncuser@'%';
      
    • Si vous n’utilisez pas SSL, exécutez les commandes suivantes :

      CREATE USER 'syncuser'@'%' IDENTIFIED BY 'userpassword';
      GRANT REPLICATION SLAVE, REPLICATION CLIENT on *.* to 'syncuser'@'%';
      SHOW GRANTS FOR syncuser@'%';
      

    Les procédures stockées effectuent toutes les fonctions de Réplication de données entrantes. Pour plus d’informations sur toutes les procédures, consultez Procédures stockées de Réplication des données entrantes. Vous pouvez exécuter ces procédures stockées dans le shell MySQL ou dans MySQL Workbench.

  3. Pour relier le serveur source Amazon RDS pour MySQL et le serveur cible Azure Database pour MySQL – Serveur flexible, connectez-vous à l’instance cible d’Azure Database pour MySQL – Serveur flexible. Définissez le serveur Amazon RDS pour MySQL en tant que serveur source en exécutant la commande suivante :

    CALL mysql.az_replication_change_master('source_server','replication_user_name','replication_user_password',3306,'<master_bin_log_file>',master_bin_log_position,'<master_ssl_ca>');
    
  4. Pour démarrer la réplication entre le serveur Amazon RDS pour MySQL source et l’instance cible d’Azure Database pour MySQL – Serveur flexible, exécutez la commande suivante :

    CALL mysql.az_replication_start;
    
  5. Pour vérifier l’état de réplication sur le serveur de réplication, exécutez la commande suivante :

    show slave status\G
    

    Si l’état des paramètres Slave_IO_Running et Slave_SQL_Running est Oui, la réplication a démarré et est en cours d’exécution.

  6. Vérifiez la valeur du paramètre Seconds_Behind_Master pour déterminer la façon dont le serveur cible est retardé.

    Si la valeur est 0, la cible a traité toutes les mises à jour du serveur source. Si la valeur est différente de 0, le serveur cible continue de traiter les mises à jour.

S’assurer que le basculement est réussi

Pour assurer un basculement réussi :

  1. Configurez les identifiants et les autorisations de niveau de base de données appropriés dans l’instance cible d’Azure Database pour MySQL – Serveur flexible.
  2. Arrêter les écritures sur le serveur Amazon RDS pour MySQL source.
  3. Vérifiez que l’instance cible d’Azure Database pour MySQL – Serveur flexible a rattrapé le serveur source et que la valeur Seconds_Behind_Master est égale à 0 pour show slave status.
  4. Appelez la procédure stockée mysql.az_replication_stop pour arrêter la réplication, car toutes les modifications ont été répliquées sur l’instance cible d’Azure Database pour MySQL – Serveur flexible.
  5. Appelez mysql.az_replication_remove_master pour supprimer la configuration de Réplication des données entrantes.
  6. Redirigez les clients et les applications clientes vers l’instance cible d’Azure Database pour MySQL – Serveur flexible.

À ce stade, la migration est terminée. Vos applications sont connectées au serveur exécutant Azure Database pour MySQL – Serveur flexible.