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

MySQL实时增量备份

462次阅读
没有评论

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

星哥玩云

星哥玩云
星哥玩云
分享互联网知识
用户数
4
文章数
19348
评论数
4
阅读量
7802331
文章搜索
热门文章
开发者必备神器:阿里云 Qoder CLI 全面解析与上手指南

开发者必备神器:阿里云 Qoder CLI 全面解析与上手指南

开发者必备神器:阿里云 Qoder CLI 全面解析与上手指南 大家好,我是星哥。之前介绍了腾讯云的 Code...
星哥带你玩飞牛NAS-6:抖音视频同步工具,视频下载自动下载保存

星哥带你玩飞牛NAS-6:抖音视频同步工具,视频下载自动下载保存

星哥带你玩飞牛 NAS-6:抖音视频同步工具,视频下载自动下载保存 前言 各位玩 NAS 的朋友好,我是星哥!...
云服务器部署服务器面板1Panel:小白轻松构建Web服务与面板加固指南

云服务器部署服务器面板1Panel:小白轻松构建Web服务与面板加固指南

云服务器部署服务器面板 1Panel:小白轻松构建 Web 服务与面板加固指南 哈喽,我是星哥,经常有人问我不...
我把用了20年的360安全卫士卸载了

我把用了20年的360安全卫士卸载了

我把用了 20 年的 360 安全卫士卸载了 是的,正如标题你看到的。 原因 偷摸安装自家的软件 莫名其妙安装...
星哥带你玩飞牛NAS-3:安装飞牛NAS后的很有必要的操作

星哥带你玩飞牛NAS-3:安装飞牛NAS后的很有必要的操作

星哥带你玩飞牛 NAS-3:安装飞牛 NAS 后的很有必要的操作 前言 如果你已经有了飞牛 NAS 系统,之前...
阿里云CDN
阿里云CDN-提高用户访问的响应速度和成功率
随机文章
12.2K Star 爆火!开源免费的 FileConverter:右键一键搞定音视频 / 图片 / 文档转换,告别多工具切换

12.2K Star 爆火!开源免费的 FileConverter:右键一键搞定音视频 / 图片 / 文档转换,告别多工具切换

12.2K Star 爆火!开源免费的 FileConverter:右键一键搞定音视频 / 图片 / 文档转换...
这个开源软件130k的star数!让电脑轻松管理安卓手机的神器

这个开源软件130k的star数!让电脑轻松管理安卓手机的神器

这个开源软件 130k 的 star 数!让电脑轻松管理安卓手机的神器 大家好,我是星哥。今天给大家安利一款宝...
星哥带你玩飞牛 NAS-10:备份微信聊天记录、数据到你的NAS中!

星哥带你玩飞牛 NAS-10:备份微信聊天记录、数据到你的NAS中!

星哥带你玩飞牛 NAS-10:备份微信聊天记录、数据到你的 NAS 中! 大家对「数据安全感」的需求越来越高 ...
安装并使用谷歌AI编程工具Antigravity(亲测有效)

安装并使用谷歌AI编程工具Antigravity(亲测有效)

  安装并使用谷歌 AI 编程工具 Antigravity(亲测有效) 引言 Antigravity...
自己手撸一个AI智能体—跟创业大佬对话

自己手撸一个AI智能体—跟创业大佬对话

自己手撸一个 AI 智能体 — 跟创业大佬对话 前言 智能体(Agent)已经成为创业者和技术人绕...

免费图片视频管理工具让灵感库告别混乱

一言一句话
-「
手气不错
如何免费使用强大的Nano Banana Pro?附赠邪修的用法

如何免费使用强大的Nano Banana Pro?附赠邪修的用法

如何免费使用强大的 Nano Banana Pro?附赠邪修的用法 前言 大家好,我是星哥,今天来介绍谷歌的 ...
150元打造低成本NAS小钢炮,捡一块3865U工控板

150元打造低成本NAS小钢炮,捡一块3865U工控板

150 元打造低成本 NAS 小钢炮,捡一块 3865U 工控板 一块二手的熊猫 B3 工控板 3865U,搭...
还在找免费服务器?无广告免费主机,新手也能轻松上手!

还在找免费服务器?无广告免费主机,新手也能轻松上手!

还在找免费服务器?无广告免费主机,新手也能轻松上手! 前言 对于个人开发者、建站新手或是想搭建测试站点的从业者...
星哥带你玩飞牛NAS硬件02:某鱼6张左右就可拿下5盘位的飞牛圣体NAS

星哥带你玩飞牛NAS硬件02:某鱼6张左右就可拿下5盘位的飞牛圣体NAS

星哥带你玩飞牛 NAS 硬件 02:某鱼 6 张左右就可拿下 5 盘位的飞牛圣体 NAS 前言 大家好,我是星...
告别Notion焦虑!这款全平台开源加密笔记神器,让你的隐私真正“上锁”

告别Notion焦虑!这款全平台开源加密笔记神器,让你的隐私真正“上锁”

  告别 Notion 焦虑!这款全平台开源加密笔记神器,让你的隐私真正“上锁” 引言 在数字笔记工...