数据是很重要的,没有备份,删库就只能跑路了,当然这只是玩笑话了。但当数据损坏或者误操作删除数据时,备份就显得尤为重要了,备份可以恢复误删除的数据,备份可以作为我们最后的“救命稻草”。MySQL 也是可以按照服务运行状态分为冷备和热备(即停机和非停机),热备份又可以分为逻辑备份和裸设备备份。按照备份后的内容量又可以分为全量备份和增量备份。

冷备:顾名思义,就是数据库处于停机未运行的状态下进行的备份。这种备份的好处是保证数据库的完整性,备份的过程也很简单恢复起来也很迅速,但是需要停机,这对于业务比较频繁的系统而言将是致命的,当用户正在下单时你数据库要停机备份,这肯定是不现实的,故能停机备份的系统都是业务比较少,使用不是很频繁的系统,即非核心系统。

冷备的备份恢复很简单,先将数据库服务停止,然后备份数据目录,恢复时替换原目录,重启服务。

停服务: ./bin/mysqladmin –uroot–proot shutdown 备份数据目录: cp –r/opt/mysql newdirectory恢复:cp –rnewdirectory /opt/mysql #将备份的数据替换原目录重启数据库即可

热备:与冷备刚好相反,数据库服务在运行状态下进行数据备份,这种情况不用停机不影响现有业务,热备又分为逻辑备份和裸文件备份。常用的备份工具有mysqldump、mydumper、XtraBackup以及MySQL5.7以后出现的mysqlpump 多线程备份,但由于mysqlpump使用的较少且不安全,不在此次讲述范围之内。

window mysql自动备份 mysql不停机备份_数据库

mysqldump

mysqldump 是系统自带的工具,也是一个最基础的备份软件,mysqldump 可以保证数据一致性且不影响业务的运行,所产生的备份,最终是要结合 binlog 进行恢复。备份的过程是先从 buffer 中找到需要备份的数据进行备份,如果 buffer 中没有,则去磁盘的数据文件中查找并调回到 buffer 里面在备份,最后形成一个可编辑的以 .sql 结尾的备份文件。

整个备份过程可通过打开通用日志来查看,使用set global general_log=on; 打开通用日志。其中,generallog 的存放路径可通过以下命令查看:

root@db 12:12: [(none)] showvariables like '%general_log_file%';

window mysql自动备份 mysql不停机备份_sql_02

观察通用日志也可明白个大概,等有机会在说吧,这里引用脚本之家的一张图片来看看备份的流程。

window mysql自动备份 mysql不停机备份_window mysql自动备份_03

备份的基本流程如下:

1.调用 FTWRL(flush tables with read lock),全局禁止读写

2.开启快照读,获取此时的快照(仅对 innodb 表起作用)

3.备份非 innodb 表数据(*.frm,*.myi,*.myd等)

4.非 innodb 表备份完毕后,释放 FTWRL锁

5.逐一备份 innodb 表数据

6.备份完成。

基本上备份就是这么一个流程,下面我们来一起看看 mysqldump 备份工作,可以使用 mysqldump –help 获取更多的信息,全是英文而且比较多,可以慢慢研究,这里仅仅介绍几个比较重要的参数。

window mysql自动备份 mysql不停机备份_数据库_04

--single-transaction

用于保证 InnoDB 备份数据时的一致性,配合可重复读 RR(repetable read)隔离级别使用,当发生事务时,读取一个事务的快照,直到备份结束时,都不会读取到事务开始之后提交的任何数据。

--all-database(-A)

导出全部数据库。

--all-tablespaces(-Y)

导出全部表空间。

--master-data

该参数有 1 和 2 两个值,如果值等于 1,就会在备份出来的文件中添加一个 CHANGE MASTER 的语句(搭建主从复制架构);如果值等于 2,就会在备份出来的文件中添加一个 CHANGE MASTER 的语句,并在语句前面添加注释符号(后期配置搭建主从架构)。

window mysql自动备份 mysql不停机备份_sql_05

--dump-slave

该参数用于在从库端备份数据,在线搭建新的从库时使用。该参数也有 1 和 2 两个值。值为 1 时,也是在备份文件中添加一个 CHANGE MASTER 的语句;值为 2 时,则会在 CHANGE MASTER 命令前增加注释信息。

--no-create-info(-t)

备份过程中,只备份表数据,并不备份表结构。

--no-data(-d)

备份过程中,只备份表结构,并不备份表数据。

--complete-insert(-c)

使用完整的 insert 语句会包含表的列信息,可提高插入效率。

--databases(-B)

备份多个数据库。参数后面所有名字参量都被看作数据库名。例如:

mysqldump -uroot –proot–databases db1 db2

--default-character-set

字符集,MySQL目前默认的字符集为 UTF8,要与备份出来的表的字符集保持一致。例如:

mysqldump -uroot -proot--all-databases --default-character-set=utf8

--quick(-q)

相当于加 sql_no_query,不缓冲查询,直接导出到标准输出。默认为打开状态,使用 --skip-quick 取消该选项

--where( -w)

只转储给定的 WHERE 条件选择的记录。请注意如果条件包含命令解释符专用空格或字符,一定要将条件引用起来。例如:

mysqldump -uroot -p --host=localhost --all-databases --where=” user=’root’”

下面看看备份恢复过程,首先备份整个数据库,命令如下:

[root@JiekeXu tmp]# mysqldump--single-transaction -uroot -proot -A >/tmp/all_20190413.sql

window mysql自动备份 mysql不停机备份_window mysql自动备份_06

备份文件说明:这里简单说明一下备份内容,文件开头首先表明了备份文件使用的 mysqldump 工具的版本号,然后是备份账号的名称和主机信息,以及备份的数据库的名称,最后是 MySQL 服务器的版本号。接下来的部分是一些 SET 语句,这些语句将一些系统变量值付给用户定义变量,以确保被恢复的数据库的系统变量和原来备份时的变量相同,例如:

/*!40101SET @OLD_CHARACTER_SET_CLIENT=@@CHARACTER_SET_CLIENT */;

注意:备份文件开始的一些语句以数字开头,这些数字代表了 MySQL 版本号,该数字告诉我们,这些语句只有在指定的 MySQL 版本或者比该版本高的情况下才能执行。例如 40101,表明这些语句只有在 MySQL 版本号为 4.01.01 或者更高条件下才可以被执行。

window mysql自动备份 mysql不停机备份_数据库_07

备份文件的最后几行 MySQL 使用 SET 语句恢复服务器系统变量原来的值。

备份文件中的"--"字符是注释语句;以"/*!"开头、"*/"结尾的语句是可执行的 MySQL 注释,这些注释可以被 MySQL 执行,但在其他数据库管理系统中将被做为注释忽略, 提高了数据库的可以移植性。

恢复全库

恢复全库时可利用 mysql 这个客户端工具来进行,命令如下:

mysql –uroot –proot tmp/all_20190413.sql

testdb 单库备份:

mysqldump --single-transaction -uroot -proottestdb >/tmp/testdb_20190413.sql

单库恢复:

mysql –uroot –proot testdb < /tmp/testdb_20190413.sql

注意:单库恢复时需要先创建数据库 create database testdb,然后在做单库恢复。

单库压缩备份:

对于业务发生比较大的公司,数据库的数据肯定会比较大,可能就会使用压缩备份,节省备份时间与磁盘空间的使用。恢复时,先解压缩,然后和前面的恢复一样。

mysqldump -uroot -proot -B testdb |gzip >/tmp/testdb_20190413.sql.gz

备份单表:

mysqldump --single-transaction -uroot -proottestdb t > /tmp/testdb_t_20190413.sql

单表恢复:

mysql –uroot –proot testdb tmp/testdb_t_20190413.sql

注意:单表恢复时,在导入符号前不需要写表名,只需要写库名即可。

备份 testdb 库下表 t的表结构信息:

mysqldump --single-transaction -uroot -proottestdb t -d > /tmp/t.sql

window mysql自动备份 mysql不停机备份_window mysql自动备份_08

备份 testdb库下表 t 的数据:

mysqldump --single-transaction -uroot -proottestdb t -t > /tmp/t_data.sql

window mysql自动备份 mysql不停机备份_数据库_09

备份 testdb库下表 t中 id<=2的记录

mysqldump --single-transaction -uroot -proottestdb t –where=”id<=2” >/tmp/t_id.sql

注意:这里的 where 后面要记得加双引号("”),否则不会被识别。

window mysql自动备份 mysql不停机备份_sql_10

作者:JiekeXu