Da ich nicht genug Ansehen habe, um nach dem höchsten Beitrag zu kommentieren, füge ich hier hinzu.
Verwenden Sie '|' auf der Linux-Plattform, um Speicherplatz zu sparen.
Danke @Hariboo, fügen Sie Ereignisse/Auslöser/Routenparameter hinzu
mysqldump -x -u [uname] -p[pass] -C --databases db_name --events --triggers --routines | sed -e 's/DEFINER[ ]*=[ ]*[^*]*\*/\*/ ' | awk '{ if (index($0,"GTID_PURGED")) { getline; while (length($0) > 0) { getline; } } else { print $0 } }' | grep -iv 'set @@' | trickle -u 10240 mysql -u username -p -h localhost DATA-BASE-NAME
einige Probleme/Tipps:
Fehler: ......nicht vorhanden bei Verwendung von LOCK TABLES
# --lock-all-tables-x , this parameter is to keep data consistency because some transaction may still be working like schedule.
# also you need check and confirm: grant all privileges on *.* to root@"%" identified by "Passwd";
ERROR 2006 (HY000) in Zeile 866: Der MySQL-Server ist verschwunden mysqldump: Errno 32 beim Schreiben erhalten
# set this values big enough on destination mysql server, like: max_allowed_packet=1024*1024*20
# use compress parameter '-C'
# use trickle to limit network bandwidth while write data to destination server
ERROR 1419 (HY000) in Zeile 32730: Sie haben nicht das SUPER-Recht und die binäre Protokollierung ist aktiviert (Sie könnte die weniger sichere Variable log_bin_trust_function_creators verwenden wollen)
# set SET GLOBAL log_bin_trust_function_creators = 1;
# or use super user import data
ERROR 1227 (42000) in Zeile 138: Zugriff verweigert; Sie benötigen (mindestens eines) der SUPER-Privilegien für diese Operation mysqldump: Errno 32 beim Schreiben erhalten
# add sed/awk to avoid some privilege issues
Ich hoffe, das hilft!