MySQL 实时增量备份, 采用 binlog 日志的好处
掌控所有更改操作, 必要时可用于恢复数据
数据库主从复制的必要条件
- [root@localhost~]# VIM /etc/my.cnf
- [mysqld]
- .. ..
- log-bin=MySQL-bin // 启用二进制日志, 并指定前缀
- .. ..
- [root@dbsvr1 ~]# service mysqld restart
确认 binlog 日志文件
新启用 binlog 后, 每次启动 MySQL 服务都会新生成一份日志文件:
- [root@localhost~]# ls /var/lib/MySQL/MySQL-bin.*
- /var/lib/MySQL/MySQL-bin.000001 /var/lib/MySQL/MySQL-bin.index
清除 binlog 日志
删除早前指定版本的 binlog 日志
RURGE MASTER LOGS TO "binlog 日志"
删除所有 binlog 日志, 重新新建日志
RESET MASTETR
分析 binlog 日志
使用 mysqlbinlog 工具
格式: mysqlbinlog [选项] 日志文件
常用选项
- --start-datatime="YYYY-mm-dd HH:MM:SS"
- --stop-datatime="YYYY-mm-dd HH:MM:SS"
--start-position = 起止位置
--stop-positon = 结束位置
- [root@localhost ~]# mysqlbinlog /var/lib/MySQL/MySQL-bin.000002
- [root@localhost ~]# mysqlbinlog --start-datetime="2018-10-20 23:30" /var/lib/MySQL/MySQL-bin.000002
利用 binlog 恢复数据
基本方法
使用 mysqlbinlog 提取历史 SQL 操作
通过管道交给 MySQL 命令重做
案例
重做第一份 binlog 所记录的更改操作
执行指定 Pos 节点范围内的 sql 命令恢复数据
根据上述日志分析, 只要恢复从 2018-10-12 20:40:50 到 2018-10-20 23:15:50 之间的操作即可. 可通过 mysqlbinlog 指定时间范围输出, 结合管道交给 msyql 命令执行导入重做:
- [root@loclahost ~]# mysqlbinlog \
- --start-datetime="2018-10-12 20:40:50" \
- --stop-datetime="2018-10-20 23:15:50" \
- /var/lib/MySQL/MySQL-bin.000002 | MySQL -u root -p
- Enter password:
若是全部重做
- [root@loclahost ~]# mysqlbinlog /var/lib/MySQL/MySQL-bin.000002 | MySQL -u root -p
- Enter password:
MySQL 备份工具
mysqlhotcopy 不足
仅适用于 MyISAM 引擎的数据库
备份过程中, 数据插入和更新操作都会被挂起
mysqldump 不足
效率较低, 备份和还原速度慢
备份过程中, 数据插入和更新操作会被挂起
XtraBackup 工具
在线热备份工具
备份过程中不锁表, 适合生产环境适用
支持整体备份和增量备份
组件一 xtrabackup:C 程序, 支持 InnoDB 和 XtraDB
组件二 innobackupex: 以 Perl 脚本封装 xtrabackup, 还支持 MyISAM
xtrabackup 基本选项 | |
基本选项 | 解释 |
--backup | 执行备份操作 |
--target-dir | 备份到目标文件夹 |
--datadir | 备份的原始文件夹 (Mysql 库的位置) |
--prepare | 准备恢复数据 |
--increamental-basedir | 增量备份时, 指定参照的完整备份路径 |
--incremental-dir | 准备恢复目录时, 指定增量备份的路径 |
1) 使用 XtraBackup 执行数据库备份
- [root@localhost~]# mkdir -p /backup/MySQL
- [root@localhost~]# xtrabackup_56 -backup --datadir=/var/lib/MySQL/ --target-dir=/backup/MySQL/
2) 确认备份好的文件数据:
[root@loclahost~]# ls /backup/MySQL/
3) 做一个增量备份 (基于前一步的完整备份)
- [root@localhost ~]# xtrabackup_56 --backup \ #xtrabackup_55 是 5.5 版本, xtrabackup_56 是 5.6 版本
- --datadir=/var/lib/MySQL/ \
- --target-dir=/backup/inc01/ \
- --incremental-basedir=/backup/MySQL/
确认备份好的文件数据:
[root@localhost~]# ls /backup/inc01/
对比完整备份, 增量备份的大小:
- [root@localhost~]# du -sh /backup/MySQL/ /backup/inc01/
- 11M /backup/MySQL/ // 完整备份的大小
- 264K /backup/inc01/
准备用于恢复的数据库目录
以 / backup/MySQL / 可用来重建 MySQL 服务器. 这种情况下, 官方建议连做两次 --prepare, 以确保数据一致性:
- [root@localhost ~]# xtrabackup_56 --prepare --target-dir=/backup/MySQL/
- [root@localhost ~]# xtrabackup_56 --prepare --target-dir=/backup/MySQL/
准备恢复 "完整备份 + 增量备份"
以 / backup/MySQL / 用来重建 MySQL 服务器, 但这种情况下需提前合并相关增量备份的数据:
先准备完整备份目录, 添加 --apply-log-only 仅应用日志:
[root@loclahost ~]# xtrabackup_56 --prepare --target-dir=/backup/MySQL --apply-log-only
然后整合增量备份的数据, 通过 --incremental-dir 选项指定增量位置:
- [root@localhost ~]# xtrabackup_56 --prepare \
- --target-dir=/backup/MySQL --apply-log-only \
- --incremental-dir=/backup/inc01
至此, 数据库已经包含增量备份.
来源: http://www.linuxidc.com/Linux/2019-09/160565.htm