阿里云-云小站(无限量代金券发放中)
【腾讯云】云服务器、云数据库、COS、CDN、短信等热卖云产品特惠抢购

MySQL实时增量备份

162次阅读
没有评论

共计 2780 个字符,预计需要花费 7 分钟才能阅读完成。

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

至此, 数据库已经包含增量备份。

正文完
星哥说事-微信公众号
post-qrcode
 
星锅
版权声明:本站原创文章,由 星锅 2022-01-22发表,共计2780字。
转载说明:除特殊说明外本站文章皆由CC-4.0协议发布,转载请注明出处。
【腾讯云】推广者专属福利,新客户无门槛领取总价值高达2860元代金券,每种代金券限量500张,先到先得。
阿里云-最新活动爆款每日限量供应
评论(没有评论)
验证码
【腾讯云】云服务器、云数据库、COS、CDN、短信等云产品特惠热卖中