0

0

如何在mysql中使用增量备份减少存储

P粉602998670

P粉602998670

发布时间:2025-11-11 08:12:02

|

305人浏览过

|

来源于php中文网

原创

启用二进制日志并定期全量备份,结合增量备份可高效节省存储;通过mysqldump和mysqlbinlog工具实现备份与恢复,按序应用全量及增量日志,合理管理binlog生命周期。

如何在mysql中使用增量备份减少存储

在 MySQL 中使用增量备份可以显著减少存储占用,因为它只记录自上次备份以来发生变化的数据,而不是每次都备份全部数据。相比全量备份,这种方式更高效、节省空间,尤其适合数据量大、更新频繁的场景。

启用二进制日志(Binary Log)

MySQL 的增量备份依赖于二进制日志功能,它记录了所有对数据库的修改操作(如 INSERT、UPDATE、DELETE)。要使用增量备份,必须先开启 binlog。

[mysqld]
log-bin=mysql-bin
server-id=1
binlog-format=ROW

  • 重启 MySQL 服务使配置生效。
  • 推荐使用 ROW 格式,能更精确地记录数据变更,适合恢复和审计。

定期执行全量备份作为基础

增量备份需要一个起点,因此要定期做一次全量备份。例如每周一次,其余时间只做增量。

  • 使用 mysqldump 创建全量备份:

mysqldump -u root -p --single-transaction --flush-logs --master-data=2 -A > full_backup.sql

  • --single-transaction 确保一致性而不锁表(适用于 InnoDB)。
  • --flush-logs 会切换到新的 binlog 文件,便于后续增量归档。
  • --master-data=2 记录当前 binlog 位置,用于恢复时确定起点。
  • 通过 binlog 实现增量备份

    每次全量备份后,只需备份新生成的 binlog 文件即可完成增量保存。

    蝉镜
    蝉镜

    AI数字人视频创作平台,100+精品数字人形象库任您选择

    下载
    • 手动复制新增的 binlog 文件(如 mysql-bin.000002、mysql-bin.000003)到安全位置。
    • 或使用 mysqlbinlog 工具导出 SQL 内容进行归档:

    mysqlbinlog mysql-bin.000002 > increment_000002.sql

  • 可结合脚本自动识别上次备份后的日志范围,避免重复。
  • 定期清理已备份且不再需要的旧 binlog(使用 PURGE BINARY LOGS)。
  • 恢复时按顺序应用备份

    恢复数据时,先导入最近的全量备份,再依次重放增量 binlog。

    • 导入全量备份:

    mysql -u root -p

  • 使用 mysqlbinlog 按顺序应用增量日志:
  • mysqlbinlog mysql-bin.000002 mysql-bin.000003 | mysql -u root -p

  • 若需恢复到某个时间点,可用 --start-datetime 和 --stop-datetime 参数筛选。
  • 基本上就这些。合理规划全量+增量策略,既能保障数据安全,又能大幅降低存储开销。关键是管理好 binlog 生命周期,避免日志无限增长占用磁盘。

    相关专题

    更多
    数据分析工具有哪些
    数据分析工具有哪些

    数据分析工具有Excel、SQL、Python、R、Tableau、Power BI、SAS、SPSS和MATLAB等。详细介绍:1、Excel,具有强大的计算和数据处理功能;2、SQL,可以进行数据查询、过滤、排序、聚合等操作;3、Python,拥有丰富的数据分析库;4、R,拥有丰富的统计分析库和图形库;5、Tableau,提供了直观易用的用户界面等等。

    673

    2023.10.12

    SQL中distinct的用法
    SQL中distinct的用法

    SQL中distinct的语法是“SELECT DISTINCT column1, column2,...,FROM table_name;”。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

    319

    2023.10.27

    SQL中months_between使用方法
    SQL中months_between使用方法

    在SQL中,MONTHS_BETWEEN 是一个常见的函数,用于计算两个日期之间的月份差。想了解更多SQL的相关内容,可以阅读本专题下面的文章。

    344

    2024.02.23

    SQL出现5120错误解决方法
    SQL出现5120错误解决方法

    SQL Server错误5120是由于没有足够的权限来访问或操作指定的数据库或文件引起的。想了解更多sql错误的相关内容,可以阅读本专题下面的文章。

    1082

    2024.03.06

    sql procedure语法错误解决方法
    sql procedure语法错误解决方法

    sql procedure语法错误解决办法:1、仔细检查错误消息;2、检查语法规则;3、检查括号和引号;4、检查变量和参数;5、检查关键字和函数;6、逐步调试;7、参考文档和示例。想了解更多语法错误的相关内容,可以阅读本专题下面的文章。

    355

    2024.03.06

    oracle数据库运行sql方法
    oracle数据库运行sql方法

    运行sql步骤包括:打开sql plus工具并连接到数据库。在提示符下输入sql语句。按enter键运行该语句。查看结果,错误消息或退出sql plus。想了解更多oracle数据库的相关内容,可以阅读本专题下面的文章。

    671

    2024.04.07

    sql中where的含义
    sql中where的含义

    sql中where子句用于从表中过滤数据,它基于指定条件选择特定的行。想了解更多where的相关内容,可以阅读本专题下面的文章。

    563

    2024.04.29

    sql中删除表的语句是什么
    sql中删除表的语句是什么

    sql中用于删除表的语句是drop table。语法为drop table table_name;该语句将永久删除指定表的表和数据。想了解更多sql的相关内容,可以阅读本专题下面的文章。

    407

    2024.04.29

    ip地址修改教程大全
    ip地址修改教程大全

    本专题整合了ip地址修改教程大全,阅读下面的文章自行寻找合适的解决教程。

    27

    2025.12.26

    热门下载

    更多
    网站特效
    /
    网站源码
    /
    网站素材
    /
    前端模板

    精品课程

    更多
    相关推荐
    /
    热门推荐
    /
    最新课程
    MySQL 教程
    MySQL 教程

    共48课时 | 1.5万人学习

    MySQL 初学入门(mosh老师)
    MySQL 初学入门(mosh老师)

    共3课时 | 0.3万人学习

    简单聊聊mysql8与网络通信
    简单聊聊mysql8与网络通信

    共1课时 | 772人学习

    关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
    php中文网:公益在线php培训,帮助PHP学习者快速成长!
    关注服务号 技术交流群
    PHP中文网订阅号
    每天精选资源文章推送

    Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号