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

mysqldump备份结合binlog日志恢复

164次阅读
没有评论

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

MySQLdump 备份一般采取全库备份加日志备份的方式,如每天执行一次全备份,每小时执行一次二进制日志备份。在 mysql 故障后可以使用全备份和日志备份将数据恢复到最后一个二进制日志备份前的任意位置或时间。

binlog 简介:

mysql 二进制日志记录着数据库的所有增删改的操作日志,在这前提上必须开启 binlog,里面包括这些操作的执行时间。显示二进制内容可以使用 mysqlbinlog 命令查看。

binlog 的作用:1,主从复制    2,恢复数据库

开启 binary log 功能

编辑 my.cnf 中的 log-bin 选项开启二进制日志:log-bin[=DIR/[filename]]。DIR 参数指定二进制文件的存储路径,filename 参数指定二进制文件的文件名,形式为 filename.number,number 的形式为 000001,000002 等。每次重启 mysql 服务或运行 mysql > flush logs; 都会生成一个新的二进制日志文件,这些二进制文件的 number 会不断地递增。其实还会生成一个名为 filename.index 的文件,这个文件中存储所有二进制日志文件的清单又称为二进制文件的索引。

mysql> show variables like ‘log_bin’:查看 bing-log 日志是否开启。

mysqldump 备份结合 binlog 日志恢复

bin-log 因为是二进制文件,不能通过文件内容查看命令直接打开查看,mysql 提供两种方式查看方式。

show binary logs; 查看 mysql server 上二进制日志

查看二进制信息的命令格式:show binlog events [in ‘log_name’] [ffrom pos] [limit [offset,] row_count]

默认显示可找到的第一个二进制日志文件中的时间,包含了日志文件名,事件的开始位置,时间类型,结束位置,信息等内容。

show binary logs 等价于 show master logs

purge binary logs 用于删除二进制日志。

purge binary logs before ‘2016-08-28 22:46:26’: 把指定时间之前的二进制文件删除

peset master 与 reset slave

前者清空 index 文件中列出的所有二进制日志,重置 index 文件为空,并创建一个新的二进制日志文件,一般用于 master 首次启动时。后者使 slave 忘记其在 master 二进制日志文件中的复制位置,它会删除 master.info,relay-log.info 和所有中继日志文件并开始一个新的中继日志文件,以便于开始一个干净的复制。使用 reset slave 前需要先关闭 slave 赋值线程。

想要查看到文件中剧吐内容并应于恢复场景还得借助 mysqlbinlog 这个工具格式:mysqlbinlog [options] log_file … 输出的内容会因日志文件的格式以及 mysqlbinlog 工具使用的选项不同而略不同。

二进制日志文件的格式包含行模式,语句模式,混合模式,基于语句的日志中事件信息包含执行的语句等,基于行的日志中事件谢谢包含的是行的变化信息。

mysqlbinlog 和可以通过 –read-from-remote-server 选项从远程服务器读取二进制日志文件,需要一些而外的连接参数,如 -h,-p,-P,- u 等,这些侧脑室近在指定了 –read-from-remote-server 后有效。

无论是本地二进制日志文件还是远程服务器上的二进制日志文件,无论是行模式,语句模式还是混合模式的二进制日志文件,被 mysqlbinlog 工具解析后都可直接应用与 mysql server 进行基于时间点,位置或数据库的恢复。

mysqldump 是 mysql 用于备份好数据转移的一个工具,主要产生一系列的 sql 语句,可以封装到文件,该文件包含所有重建你的数据库所需要 sql 命令如 create database,create table,insert 等等。可以用来实现轻量级的快速迁移或恢复数据库。

mysqldump 是将数据表导成 sql 脚本文件,在不同的 mysql 版本之间升级时相对比较合适,也是最常用的备份方法。mysqldump 一般在数据量很少的时候可以用于备份,当数据量比较大的情况下,就不建议用 mysqldump 工具进行备份。

数据库的导出, 导出对象说明:mysqldump 可以针对单个表,多个表,单个数据库,多个数据库,所有数据库进行导出的操作。

mysqldump [options] db_name [tbl_name …] 导出指定数据库或单个表

mysqldump [options] –databases db_name…    导出多个数据库

mysqldump [optoins] –all-databases    导出所有

mysqldump - u 用户名 -p –flush-logs test > /opt/test.sql  –flush-logs 这个选项就会完整备份的时候重新开启一个新 binlog。

数据库的导入

mysql - u 用户名 -p test / /opt/test.sql

全库备份 +binlog 的数据恢复

环境准备与备份还原:

线程开启 binlog

本文永久更新链接地址 :http://www.linuxidc.com/Linux/2017-03/141898.htm

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