MySQL备份恢复需逻辑与物理并用:mysqldump适合中小跨平台场景,XtraBackup等物理备份支持热备;全量备份加--single-transaction等参数保障一致性,增量依赖开启binlog;恢复前须验证备份完整性。

Linux 下 MySQL 和 PostgreSQL 的备份、恢复与性能优化,核心在于理解原理、选对工具、定期验证。 不是堆砌命令,而是建立可落地的运维习惯。
MySQL 备份与恢复:mysqldump 与物理备份并用
逻辑备份(mysqldump)适合中小规模、需跨版本或跨平台迁移的场景;物理备份(如 mysqlbackup 或 Percona XtraBackup)速度快、支持热备,适合中大型生产库。
- 日常全量逻辑备份建议加
--single-transaction --routines --triggers --events,保障一致性且导出存储过程和事件 - 增量备份依赖 binlog,务必开启
log-bin并配置expire_logs_days防止磁盘打满 - 恢复前先检查备份文件完整性:
zcat backup.sql.gz | head -n 20看是否有CREATE DATABASE或SET @@SESSION.SQL_LOG_BIN=0 - 生产环境避免直接
mysql ,推荐用mysql --init-command="SET FOREIGN_KEY_CHECKS=0;" 避免外键冲突
PostgreSQL 备份与恢复:pg_dump + WAL 归档是黄金组合
逻辑备份用 pg_dump(单库)或 pg_dumpall(集群级),配合 WAL 归档实现 PITR(基于时间点恢复)。
本版升级功能:1、增加“系统参数设置”功能,可在线管理编辑全站数据库路径、备份路径,无须到程序代码下更改;2、改进后台管理员权限分配问题,严谨、完善、安全的根限分配细分到每个功能页面的列表查看权限、添加权限、编辑权限、删除权限都可以在线分配,确保系统在多用户管理下,安全稳定运行;3、更新优化数据库操作,在线备份、压缩、恢复数据库,管理登录日志;4、增加&am
- 全量备份建议使用
pg_dump -Fc -v -f db.dump -U postgres dbname,-Fc生成自包含的二进制格式,支持并行恢复和选择性还原 - 开启归档必须设置
archive_mode = on、archive_command(如cp %p /path/to/archive/%f),并确保归档目录有写权限和足够空间 - 恢复时先还原基础备份,再复制归档 WAL 到
pg_wal(旧版为pg_xlog),最后在recovery.conf(PG12+ 改为standby.signal + postgresql.auto.conf)中指定restore_command和recovery_target_time - 定期用
pg_archivecleanup清理过期 WAL,避免归档目录无限膨胀
通用备份策略:不验证=没备份
备份脚本再完美,不验证就等于没做。自动化不能代替有效性检查。
- 每天随机抽取一个备份,在测试环境解压/导入后执行
SELECT COUNT(*) FROM pg_tables(PG)或SHOW TABLE STATUS(MySQL),确认表结构和行数基本合理 - 记录每次备份的起始/结束时间、大小、校验和(
sha256sum),写入日志并推送告警(如备份耗时突增 200% 或大小减少 90%) - 每季度执行一次完整恢复演练:从备份拉起新实例,接入只读应用流量,验证查询逻辑与延迟是否正常
- 备份文件禁止存放在数据库所在磁盘分区,优先使用独立挂载的 NFS 或对象存储(如 S3 兼容接口),并启用服务端加密
性能优化:从慢查切入,靠监控定方向
优化不是调几个参数,而是定位瓶颈、量化影响、小步验证。
- MySQL:开启
slow_query_log,设long_query_time=1,用pt-query-digest分析日志,重点关注Rows_examined/Rows_sent比值高的语句,优先加索引或改写 JOIN 顺序 - PostgreSQL:启用
log_min_duration_statement = 1000,结合pg_stat_statements扩展看 top SQL 的total_time和shared_blks_hit_ratio,命中率低于 95% 要查内存配置或缓存设计 - 共性调优项:
innodb_buffer_pool_size(MySQL)或shared_buffers(PG)建议设为物理内存的 25%–40%,但避免超过系统可用内存导致 swap - 连接数不是越多越好,MySQL 的
max_connections和 PG 的max_connections应匹配应用连接池配置,空闲连接超时(wait_timeout/tcp_keepalives_idle)要合理设置防僵死









