Sie können das Dienstprogramm mysqldump direkt mit Ihrer MySQL-Datenbank ausführen und dabei beliebige Optionen verwenden. Wenn Sie die Daten jedoch exportieren, um sie in eine Cloud SQL-Datenbank zu importieren, verwenden Sie das Dienstprogramm „mysqldump“ mit den folgenden Flags:
--databases
Geben Sie eine explizite Liste der Datenbanken an, die exportiert werden sollen. Diese Liste darf keine Systemdatenbanken (sys
,mysql
,performance_schema
undinformation_schema
) enthalten.--hex-blob
Enthält die Datenbank Binärfelder, gewährleistet dieses Flag, dass die Binärfelder ordnungsgemäß importiert werden.--single-transaction
Startet eine Transaktion vor der Ausführung. Anstatt die gesamte Datenbank zu sperren, kann mysqldump die Datenbank im aktuellen Zustand lesen und so eine konsistente Daten-Dumpdatei erzeugen.--routines
Um gespeicherte Prozeduren und Funktionen einzubeziehen.Wenn Sie
mysqldump
Version 8 oder höher verwenden, um MySQL-Datenbanken mit einer älteren Version als 8 zu exportieren:--column-statistics=0
Mit diesem Flag wird die Tabelle COLUMN_STATISTICS aus dem Datenbankexport entfernt, um den Fehler
Unknown table 'COLUMN_STATISTICS' in information_schema (1109)
zu vermeiden. Weitere Informationen finden Sie unter Probleme diagnostizieren.
Außerdem wird empfohlen, die folgenden Flags zu verwenden:
--no-autocommit
--default-character-set=utf8mb4
--master-data
Führen Sie den folgenden Befehl auf einem Computer aus, der über eine Netzwerkverbindung mit Ihrem MySQL-Server verbunden ist:
mysqldump \
-h [SOURCE_ADDR] -P [SOURCE_PORT] -u [USERNAME] -p \
--databases [DBS] \
--hex-blob \
--no-autocommit \
--default-character-set=utf8mb4 \
--master-data=1 \
--single-transaction \
--routines \
| gzip \
| gcloud storage cp - gs://[BUCKET_NAME]/[DUMP_FILENAME].gz
Wenn die Quelle der Migration ein relationaler Datenbankdienst (RDS) für MySQL ist:
- Das Attribut
master-data
wird nicht unterstützt. - Wenn der Quelldatenbankserver GTID unterstützt, verwenden Sie das Attribut
--set-gtid-purged=on
. Verwenden Sie andernfalls dieses Attribut nicht. - Wenn Sie Ihre Daten mit einem manuellen Dump migrieren, führen Sie die Migration mit aktivierter GTID durch.
Der Befehl kann wie im folgenden Beispiel aussehen:
mysqldump \
-h [SOURCE_ADDR] -P [SOURCE_PORT] -u [USERNAME] -p \
--databases [DBS] \
--hex-blob \
--no-autocommit \
--default-character-set=utf8mb4 \
--set-gtid-purged=on \
--single-transaction \
--routines \
| gzip \
| gcloud storage cp - gs://[BUCKET_NAME]/[DUMP_FILENAME].gz
Außerdem sollten Sie RDS-Instanzen so konfigurieren, dass binäre Logs länger aufbewahrt werden. Der Befehl kann wie im folgenden Beispiel aussehen:
# Sets the retention period to one week.
call mysql.rds_set_configuration('binlog retention hours', 168);
Ersetzen Sie die Attribute ([PROPERTIES_IN_BRACKETS]) durch folgende Werte:
Attribut | Wert |
[SOURCE_ADDR] | Die IPv4-Adresse oder der Hostname des Quelldatenbankservers. |
[SOURCE_PORT] | Der Port für den Quelldatenbankserver. |
[USERNAME] | Das MySQL-Nutzerkonto. |
[DBS] | Eine durch Leerzeichen getrennte Liste der Datenbanken auf dem Quelldatenbankserver, die in den Dump aufgenommen werden sollen. Verwenden Sie den MySQL-Befehl SHOW DATABASES , um Ihre Datenbanken aufzulisten. |
[BUCKET_NAME] | Der vom Nutzer erstellte Bucket in Cloud Storage, der zum Speichern der Dumpdatei verwendet wird (z. B. replica-bucket ). |
[DUMP_FILENAME] | Der Dateiname des Dumps, der auf die Dateiendung .gz endet (z. B. source-database.sql.gz ). |