mysql如何进行全量数据库备份_mysqldump工具的使用技巧

张开发
2026/4/18 2:59:27 15 分钟阅读

分享文章

mysql如何进行全量数据库备份_mysqldump工具的使用技巧
备份前必须确认用户具备SELECT、LOCK TABLES、RELOAD权限且MySQL未启用read_onlyON、max_allowed_packet足够大全量备份需加--routines、--events、--triggers、--single-transaction和--set-gtid-purgedOFF。备份前必须确认的三个权限和状态用 mysqldump 做全量备份不是敲完命令就完事。最常卡在权限不足或数据库锁不住——比如你有 SELECT 权限但没 LOCK TABLES或者连 RELOAD用于 --single-transaction都没有dump 就会直接报错 Access denied; you need (at least one of) the LOCK TABLES privilege(s) for this operation。确保用户至少有SELECT、LOCK TABLES、SHOW VIEW如果库含视图、TRIGGER含触发器时、RELOAD启用 --single-transaction 或 --flush-logs 时必需检查 MySQL 是否启用了 read_onlyON —— 这会让 mysqldump --single-transaction 失败因为内部需要临时写一个一致性位点确认 max_allowed_packet 足够大尤其含大 BLOB 字段时否则 dump 中途断在某张表报错 Packets larger than max_allowed_packet are not allowed全库备份命令怎么写才不丢数据默认不加参数的 mysqldump -u root -p --all-databases 看似省事实际会漏掉 information_schema 和 performance_schemaMySQL 5.7 默认跳过更危险的是它不自动加 --routines 和 --events存储过程、函数、事件全丢了。安全全量备份推荐组合mysqldump -u root -p --all-databases --routines --events --triggers --single-transaction --set-gtid-purgedOFF full_backup.sql--single-transaction 仅对 InnoDB 有效MyISAM 表仍会被锁若库混用引擎得改用 --lock-all-tables但停写时间更长--set-gtid-purgedOFF 必须显式加——否则在 GTID 模式下dump 文件开头会写 SET GLOBAL.GTID_PURGED还原时可能和目标实例 GTID 冲突导致复制中断压缩备份和分库备份的实用技巧全库几百 GB 时直接生成 SQL 文件再压缩既占磁盘又慢。不如边 dump 边压还能按需拆库。 ARTi.PiCS ARTi.PiCS是一款由AI驱动的虚拟头像生产器可以生成200多个不同风格的酷炫虚拟头像

更多文章