Amazon RDS for MySQL migreren naar Azure Database for MySQL met behulp van replicatie van inkomende gegevens
Notitie
Dit artikel bevat verwijzingen naar de term slave, een term die Microsoft niet meer gebruikt. Zodra de term uit de software wordt verwijderd, verwijderen we deze uit dit artikel.
U kunt methoden zoals MySQL-dump en -herstel, MySQL Workbench Exporteren en importeren of Azure Database Migration Service gebruiken om uw MySQL-databases te migreren naar Azure Database for MySQL Flexible Server. U kunt uw workloads migreren met minimale downtime door gebruik te maken van een combinatie van opensource-hulpprogramma's zoals mysqldump of mydumper en myloader met Data-in Replication.
Replicatie van inkomende gegevens is een techniek waarmee gegevenswijzigingen van de bronserver naar de doelserver worden gerepliceerd op basis van de positiemethode van het binaire logboekbestand. In dit scenario schrijft het MySQL-exemplaar dat werkt als de bron (waarop de databasewijzigingen afkomstig zijn) updates en wijzigingen als gebeurtenissen in het binaire logboek. De informatie in het binaire logboek wordt opgeslagen in verschillende indelingen voor logboekregistratie, afhankelijk van de wijzigingen in de database die worden vastgelegd. Replica's zijn geconfigureerd voor het lezen van het binaire logboek uit de bron en het uitvoeren van de gebeurtenissen in het binaire logboek in de lokale database van de replica.
Stel gegevens repliceren in Azure Database for MySQL - Flexible Server in om gegevens van een bron-MySQL-server te synchroniseren met een mySQL-doelserver. U kunt een selectieve cutover van uw toepassingen uitvoeren van de primaire (of brondatabase) naar de replica (of doeldatabase).
In deze zelfstudie leert u hoe u Gegevens-in-replicatie instelt tussen een bronserver waarop Amazon Relational Database Service (RDS) voor MySQL wordt uitgevoerd en een doelserver waarop Azure Database for MySQL Flexible Server wordt uitgevoerd.
Prestatieoverwegingen
Voordat u aan deze zelfstudie begint, moet u rekening houden met de gevolgen voor de prestaties van de locatie en de capaciteit van de clientcomputer die u gaat gebruiken om de bewerking uit te voeren.
Clientlocatie
Dump- of herstelbewerkingen uitvoeren vanaf een clientcomputer die wordt gestart op dezelfde locatie als de databaseserver:
- Voor Azure Database for MySQL Flexible Server-exemplaren moet de clientcomputer zich in hetzelfde virtuele netwerk en dezelfde beschikbaarheidszone bevinden als de doeldatabaseserver.
- Voor bronexemplaren van Amazon RDS-database moet het clientexemplaren zich in dezelfde Amazon Virtual Private Cloud en beschikbaarheidszone bevinden als de brondatabaseserver. In het voorgaande geval kunt u dumpbestanden verplaatsen tussen clientcomputers met behulp van protocollen voor bestandsoverdracht, zoals FTP of SFTP, of uploaden naar Azure Blob Storage. Als u de totale migratietijd wilt verminderen, comprimeert u bestanden voordat u ze overbrengt.
Clientcapaciteit
Ongeacht waar de clientcomputer zich bevindt, vereist het voldoende reken-, I/O- en netwerkcapaciteit om de aangevraagde bewerkingen uit te voeren. De algemene aanbevelingen zijn:
- Als de dump of herstel realtime verwerking van gegevens omvat, bijvoorbeeld compressie of decomprimatie, kiest u een instantieklasse met ten minste één CPU-kern per dump of herstelthread.
- Zorg ervoor dat er voldoende netwerkbandbreedte beschikbaar is voor het clientexemplaren. Gebruik instantietypen die ondersteuning bieden voor de functie versneld netwerken. Zie de sectie Versneld netwerken in de netwerkhandleiding voor virtuele Azure-machines voor meer informatie.
- Zorg ervoor dat de opslaglaag van de clientcomputer de verwachte lees-/schrijfcapaciteit biedt. U wordt aangeraden een virtuele Azure-machine te gebruiken met Premium SSD-opslag.
Vereisten
Voor het voltooien van deze zelfstudie hebt u het volgende nodig:
Installeer de mysqlclient op uw clientcomputer om een dump te maken en voer een herstelbewerking uit op uw Azure Database for MySQL Flexible Server-exemplaar.
Voor grotere databases installeert u mydumper en myloader voor parallelle dumping en het herstellen van databases.
Notitie
Mydumper kan alleen worden uitgevoerd op Linux-distributies. Zie Mydumper installeren voor meer informatie.
Maak een exemplaar van Azure Database for MySQL Flexible Server waarop versie 5.7 of 8.0 wordt uitgevoerd.
Belangrijk
Als uw doel Azure Database for MySQL Flexible Server met zone-redundante hoge beschikbaarheid (HA) is, moet u er rekening mee houden dat replicatie van gegevens niet wordt ondersteund voor deze configuratie. Als tijdelijke oplossing stelt u tijdens het maken van de server zone-redundante hoge beschikbaarheid in:
- Maak de server waarvoor zone-redundante hoge beschikbaarheid is ingeschakeld.
- Hoge beschikbaarheid uitschakelen.
- Volg het artikel voor het instellen van inkomende replicatie.
- Na de cutover verwijdert u de configuratie voor replicatie van inkomende gegevens.
- Hoge beschikbaarheid inschakelen.
Zorg ervoor dat verschillende parameters en functies correct zijn geconfigureerd en ingesteld, zoals beschreven:
- Om compatibiliteitsredenen moet u de bron- en doeldatabaseservers in dezelfde MySQL-versie hebben.
- Een primaire sleutel in elke tabel hebben. Een gebrek aan primaire sleutels in tabellen kan het replicatieproces vertragen.
- Zorg ervoor dat de tekenset van de bron en de doeldatabase hetzelfde zijn.
- Stel de
wait_timeout
parameter in op een redelijke tijd. De tijd is afhankelijk van de hoeveelheid gegevens of werkbelasting die u wilt importeren of migreren. - Controleer of alle tabellen Gebruikmaken van InnoDB. Azure Database for MySQL Flexible Server ondersteunt alleen de InnoDB-opslagengine.
- Voor tabellen met veel secundaire indexen of grote tabellen zijn overhead-effecten voor prestaties zichtbaar tijdens het herstellen. Wijzig de dumpbestanden zodat de
CREATE TABLE
instructies geen secundaire sleuteldefinities bevatten. Nadat u de gegevens hebt geïmporteerd, maakt u secundaire indexen opnieuw om de prestatiestraf te voorkomen tijdens het herstelproces.
Ten slotte moet u zich voorbereiden op replicatie van inkomende gegevens:
- Controleer of het doelexemplaren van Azure Database for MySQL Flexible Server verbinding kunnen maken met de bron-Amazon RDS for MySQL-server via poort 3306.
- Zorg ervoor dat de bron-Amazon RDS voor MySQL-server zowel inkomend als uitgaand verkeer op poort 3306 toestaat.
- Zorg ervoor dat u site-naar-site-connectiviteit met uw bronserver biedt met behulp van Azure ExpressRoute of Azure VPN Gateway. Zie de documentatie van Azure Virtual Network voor meer informatie over het maken van een virtueel netwerk. Zie ook de quickstart-artikelen met stapsgewijze details.
- Configureer de netwerkbeveiligingsgroepen van de brondatabaseserver om het IP-adres van de doel-Azure Database for MySQL Flexible Server toe te staan.
Belangrijk
Als het Amazon RDS-bronexemplaren voor MySQL GTID_mode ingesteld op AAN, moet het doelexemplaren van Azure Database for MySQL Flexible Server ook GTID_mode ingesteld op AAN.
Het doelexemplaren van Azure Database for MySQL configureren
Het doelexemplaren van Azure Database for MySQL Flexible Server configureren. Dit is het doel voor replicatie van inkomende gegevens:
Stel de
max_allowed_packet
parameterwaarde in op het maximum van 1073741824, wat 1 GB is. Deze waarde voorkomt eventuele overloopproblemen met betrekking tot lange rijen.Stel tijdens de migratie de
slow_query_log
parameters ,general_log
audit_log_enabled
enquery_store_capture_mode
parameters in op UIT om eventuele overhead met betrekking tot querylogboekregistratie te voorkomen.Schaal de rekenkracht van het Azure Database for MySQL Flexible Server-doelexemplaren omhoog tot maximaal 64 vCores. Deze grootte biedt meer rekenresources bij het herstellen van de databasedump van de bronserver.
U kunt de berekening altijd terugschalen om te voldoen aan de vereisten van uw toepassing nadat de migratie is voltooid.
Schaal de opslaggrootte omhoog om meer IOPS te krijgen tijdens de migratie of verhoog de maximale IOPS voor de migratie.
Notitie
De beschikbare maximale IOPS worden bepaald door de rekengrootte. Zie de sectie IOPS in Compute- en opslagopties in Azure Database for MySQL Flexible Server voor meer informatie.
De bron-Amazon RDS voor MySQL-server configureren
De MySQL-server die wordt gehost in Amazon RDS voorbereiden en configureren. Dit is de bron voor replicatie van gegevens in:
Controleer of binaire logboekregistratie is ingeschakeld op de bron-Amazon RDS voor MySQL-server. Controleer of automatische back-ups zijn ingeschakeld of controleer of er een leesreplica bestaat voor de bron-Amazon RDS voor MySQL-server.
Zorg ervoor dat de binaire logboekbestanden op de bronserver worden bewaard totdat de wijzigingen zijn toegepast op het doelexemplaren van Azure Database for MySQL Flexible Server.
Met replicatie van gegevens beheert Azure Database for MySQL Flexible Server het replicatieproces niet.
Als u de bewaarperiode van het binaire logboek op de Amazon RDS-bronserver wilt controleren om het aantal uren te bepalen dat de binaire logboeken worden bewaard, roept u de
mysql.rds_show_configuration
opgeslagen procedure aan: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) |
Als u de bewaarperiode voor binaire logboeken wilt configureren, voert u de
rds_set_configuration
opgeslagen procedure uit om ervoor te zorgen dat de binaire logboeken gedurende de gewenste tijd op de bronserver worden bewaard. Voorbeeld:Call mysql.rds_set_configuration('binlog retention hours', 96);
Als u een dump maakt en herstelt, helpt de voorgaande opdracht u snel bij te komen met de deltawijzigingen.
Notitie
Zorg ervoor dat er voldoende schijfruimte is om de binaire logboeken op de bronserver op te slaan op basis van de gedefinieerde bewaarperiode.
Er zijn twee manieren om een dump van gegevens vast te leggen van de Amazon RDS-bronserver voor MySQL. Eén benadering omvat het vastleggen van een dump van gegevens rechtstreeks vanaf de bronserver. De andere benadering omvat het vastleggen van een dump van een Amazon RDS voor MySQL-leesreplica.
Een dump van gegevens rechtstreeks vanaf de bronserver vastleggen:
Zorg ervoor dat u de schrijfbewerkingen van de toepassing enkele minuten stopt om een transactioneel consistente dump van gegevens op te halen.
U kunt de
read_only
parameter ook tijdelijk instellen op een waarde van 1 , zodat schrijfbewerkingen niet worden verwerkt wanneer u een dump met gegevens vastlegt.Nadat u de schrijfbewerkingen op de bronserver hebt gestopt, verzamelt u de naam en verschuiving van het binaire logboekbestand door de opdracht
Mysql> Show master status;
uit te voeren.Sla deze waarden op om de replicatie te starten vanuit uw Azure Database for MySQL Flexible Server-exemplaar.
Voer de volgende opdracht uit
mysqldump
om een dump van de gegevens te maken:$ mysqldump -h hostname -u username -p –single-transaction –databases dbnames –order-by-primary> dumpname.sql
Als het stoppen van schrijfbewerkingen op de bronserver geen optie is of de prestaties van dumpinggegevens niet acceptabel zijn op de bronserver, legt u een dump vast op een replicaserver:
Maak een Amazon MySQL-leesreplica met dezelfde configuratie als de bronserver. Maak vervolgens de dump daar.
Laat de Amazon RDS for MySQL leesreplica inhalen met de bron-Amazon RDS for MySQL-server.
Wanneer de replicavertraging 0 bereikt op de leesreplica, stopt u de replicatie door de opgeslagen procedure
mysql.rds_stop_replication
aan te roepen.call mysql.rds_stop_replication;
Als de replicatie is gestopt, maakt u verbinding met de replica. Voer vervolgens de
SHOW SLAVE STATUS
opdracht uit om de naam van het huidige binaire logboekbestand op te halen uit het veld Relay_Master_Log_File en de positie van het logboekbestand uit het veld Exec_Master_Log_Pos .Sla deze waarden op om de replicatie te starten vanuit uw Azure Database for MySQL Flexible Server-exemplaar.
Als u een dump van de gegevens wilt maken van de Amazon RDS for MySQL-leesreplica, voert
mysqldump
u de volgende opdracht uit:$ mysqldump -h hostname -u username -p –single-transaction –databases dbnames –order-by-primary> dumpname.sql
Notitie
U kunt mydumper ook gebruiken voor het vastleggen van een geparallelliseerde dump van uw gegevens uit uw bron Amazon RDS for MySQL-database. Zie Grote databases migreren naar Azure Database for MySQL Flexible Server met behulp van mydumper/myloader voor meer informatie.
Bron- en replicaservers koppelen om data-in-replicatie te starten
Als u de database wilt herstellen met behulp van systeemeigen mysql-herstel, voert u de volgende opdracht uit:
$ mysql -h <target_server> -u <targetuser> -p < dumpname.sql
Notitie
Als u in plaats daarvan myloader gebruikt, raadpleegt u Grote databases migreren naar Azure Database for MySQL Flexible Server met behulp van mydumper/myloader.
Meld u aan bij de bron-Amazon RDS for MySQL-server en stel een replicatiegebruiker in. Verdeel vervolgens de benodigde bevoegdheden aan deze gebruiker.
Als u SSL gebruikt, voert u de volgende opdrachten uit:
CREATE USER 'syncuser'@'%' IDENTIFIED BY 'userpassword'; GRANT REPLICATION SLAVE, REPLICATION CLIENT on *.* to 'syncuser'@'%' REQUIRE SSL; SHOW GRANTS FOR syncuser@'%';
Als u geen SSL gebruikt, voert u de volgende opdrachten uit:
CREATE USER 'syncuser'@'%' IDENTIFIED BY 'userpassword'; GRANT REPLICATION SLAVE, REPLICATION CLIENT on *.* to 'syncuser'@'%'; SHOW GRANTS FOR syncuser@'%';
Opgeslagen procedures doen alle functies voor replicatie van gegevens. Zie Opgeslagen procedures voor gegevens in replicatie voor meer informatie over alle procedures. U kunt deze opgeslagen procedures uitvoeren in de MySQL-shell of MySQL Workbench.
Als u de Amazon RDS for MySQL-bronserver en de doelserver van Azure Database for MySQL Flexible Server wilt koppelen, meldt u zich aan bij het doelexemplaren van Azure Database for MySQL Flexible Server. Stel de Amazon RDS voor MySQL-server in als de bronserver door de volgende opdracht uit te voeren:
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>');
Voer de volgende opdracht uit om de replicatie tussen de bron-Amazon RDS for MySQL-server en het doelexemplaren van Azure Database for MySQL Flexible Server te starten:
CALL mysql.az_replication_start;
Voer de volgende opdracht uit om de status van de replicatie op de replicaserver te controleren:
show slave status\G
Als de status van de
Slave_IO_Running
enSlave_SQL_Running
parameters Ja is, is de replicatie gestart en heeft deze de status Actief.Controleer de waarde van de
Seconds_Behind_Master
parameter om te bepalen hoe vertraagd de doelserver is.Als de waarde 0 is, heeft het doel alle updates van de bronserver verwerkt. Als de waarde iets anders is dan 0, verwerkt de doelserver nog steeds updates.
Een geslaagde cutover garanderen
Een geslaagde cutover garanderen:
- Configureer de juiste aanmeldingen en machtigingen op databaseniveau in het doelexemplaren van Azure Database for MySQL Flexible Server.
- Stop schrijfbewerkingen naar de bron-Amazon RDS voor MySQL-server.
- Zorg ervoor dat het azure Database for MySQL Flexible Server-doelexemplaren de bronserver heeft opgepikt en dat de
Seconds_Behind_Master
waarde 0 is.show slave status
- Roep de opgeslagen procedure
mysql.az_replication_stop
aan om de replicatie te stoppen omdat alle wijzigingen zijn gerepliceerd naar het Azure Database for MySQL Flexible Server-doelexemplaren. - Aanroep
mysql.az_replication_remove_master
om de replicatieconfiguratie voor inkomende gegevens te verwijderen. - Clients en clienttoepassingen omleiden naar het doelexemplaren van Azure Database for MySQL Flexible Server.
Op dit moment is de migratie voltooid. Uw toepassingen zijn verbonden met de server waarop Azure Database for MySQL Flexible Server wordt uitgevoerd.