mysqldump备份通常采起全库备份加日志备份的方式,如天天执行一次全备份,每小时执行一次二进制日志备份。在mysql故障后可使用全备份和日志备份将数据恢复到最后一个二进制日志备份前的任意位置或时间。mysql
binlog简介:sql
mysql二进制日志记录着数据库的全部增删改的操做日志,在这前提上必须开启binlog,里面包括这些操做的执行时间。显示二进制内容可使用mysqlbinlog命令查看。数据库
binlog的做用:1,主从复制 2,恢复数据库服务器
开启binary log功能ide
编辑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日志是否开启。spa
bin-log由于是二进制文件,不能经过文件内容查看命令直接打开查看,mysql提供两种方式查看方式。
线程
show binary logs; 查看mysql server上二进制日志
日志
查看二进制信息的命令格式:show binlog events [in 'log_name'] [ffrom pos] [limit [offset,] row_count]
server
默认显示可找到的第一个二进制日志文件中的时间,包含了日志文件名,事件的开始位置,时间类型,结束位置,信息等内容。
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