MySQL的备份与还原,非常规备份,全量备份,增量备份
Posted
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了MySQL的备份与还原,非常规备份,全量备份,增量备份相关的知识,希望对你有一定的参考价值。
参考技术A1:官方百万级别的测试数据库:
官方测试数据库github网址:https://github.com/datacharmer/test_db
下载到目录,解压即可,运行命令:
2:自己创建简单测试数据库:
快速随机生成测试语言的网站:https://generatedata.com/
选择sql和想生成的字段,点击生成Generate!生成即可。
在mysql输入生成的语句即可。
3:测试备份还原时用到的命令
删库跑路测试(先备份好)
还原后查询库的表数据是否完整。
采用复制整个数据存放目录
1:查看数据库数据存放位置
有两种方法:
1):在数据库中用命令 show variables like \'datadir\'; 查看
2):在配置文件中查看,配置了 datadir 目录的可查看。没有配置的默认为 /var/lib/mysql/ 位置
Linux中查看配置文件
2:复制目录或者目录下某个数据库名
3:还原时直接复制文件夹到数据库目录即可
mysqldump又可叫做全量备份。
参数 --databases 同 -B ,单独一个库,也可省略。
1、备份命令mysqldump格式
格式:mysqldump -h主机名 -P端口 -u用户名 -p密码 database 数据库名 > 文件名.sql
备份testDatabase数据库
2、备份MySQL数据库为带删除表的格式
备份MySQL数据库为带删除表的格式,能够让该备份覆盖已有数据库而不需要手动删除原有数据库。
3、直接将MySQL数据库压缩备份
备份并压缩
4、备份MySQL数据库某个(些)表
备份testDatabase中的myTable表,不需要用参数 --databases 或者 -B
5、同时备份多个MySQL数据库
同时备份testDatabase和 employees两个库
6、备份服务器上所有数据库
参数 --all-databases 同 -A
7、还原MySQL数据库的命令
1) 不指定数据名还原,默认生成原数据库名称,还原所有数据库。
2) 指定数据名还原,还原指定单个数据库,需在数据库种预先创建一个testDatabase名称。
3) 还原压缩的MySQL数据库
4) 进入数据库用source导入
增量备份是针对于数据库的bin-log日志进行备份的,增量备份是在全量的基础上进行操作的。增量备份主要是靠mysql记录的bin-log日志。
1:查看是否开启bin-log日志
进入mysql输入命令可查看。
显示如下为开启状态,日志文件在/var/lib/mysql/以binlog.00001的格式保存。
如未开启,需要在配置文件种配置
2:查看目前使用的bin-log日志文件
进入mysql查看命令。
显示如下,目前使用的是binlog.000022文件,所有操作都记录在此文件。
查看当前testDatabase的表myTable数据如下,
3:刷新日志,使用新的日志文件(备份)
在命令端执行命令
日志文件从 binlog.000022 变为 binlog.000023
这时相当与已经备份成功,备份文件即为上次的binlog.000022日志文件。
4:删除数量,从日志还原数据
1) 删除ABC行
查询以及没有ABC行列。
2) 恢复数据ABC行
退出mysql,在命令端用mysqlbinlog命令恢复到binlog.000022日志状态。
进入数据库再次查看数据,ABC已经恢复。
增量备份完成。
MySQL备份与还原
MySQL备份与还原
一、数据备份
1.备份方式
1)全量备份:对数据库完整的备份
2)增量备份:从最后一次备份后改变的文件
3)差异备份:在最后一次完整后被修改的文件
建议:全量+增量=1月全量,1周增量
2.备份分类
1)物理备份
冷备份:关闭数据后
热备份:数据运行状态时
2)逻辑备份
对逻辑对象(表、库)备份
二、完整备份
1.特性
1)数据完整
2)数据较庞大
3)时间长,重复性数据
打包、cp、mysqldump
案例:
1.准备数据
//新建hehe数据库 mysql> create database hehe;
//向hehe数据库添加a表和格式 mysql>create table hehe.a(user char(4),password char(8),primary key(user));
//插入表内数据 mysql> insert into hehe.a values(‘Zhangs‘,‘123‘);
//插入表内数据 mysql> insert into hehe.a values(‘Lisi‘,‘123‘);
2.备份
方式一:(冷备份)
//关闭数据库 /etc/init.d/mysqld stop
//备份数据库 tar -zcvf /root/mysql.bak /usr/local/mysql/data/
方式二:(热备份)
mysqldump -u root -p --all-database >/root/mysql.sql //热备份,数据库不需停止,备份所有数据库
3.模拟故障
//误删除hehe数据库 mysql> drop database hehe;
4.恢复
方式一:(冷恢复)
//关闭数据库 /etc/init.d/mysqld stop
//tar -zxvf /root/mysql.bak -C /
方式二:(热恢复)
//进入数据执行命令 mysql> source /root/mysql.sql
方式三:(热恢复)
//恢复数据mysql -u root -p < /root/mysql.sql
三、增量备份
1.Mysql不自带增量备份方式,需通过Binary logs(记录所有更改操作)实现增量
案例:
1)准备数据(同上准备数据)
2)开启二进制日志
//编辑MySQL数据库配置文件 vim /etc/my.cnf
//重启MySQL服务 /etc/init.d/mysqld restart
3.完整备份
方式一:(冷备份)
/etc/init.d/mysqld stop
//备份数据库 tar -zcvf /root/mysql.bak /usr/local/mysql/data/
方式二:(热备份)
mysqldump -u root -p --all-database >/root/mysql.sql //热备份,数据库不需停止,备份所有数据库
4.数据增加
//查看二进制文件 ls /usr/local/mysql/data/
//截取二进制文件准备增加数据 mysqladmin -u root -p flush-logs
//查看二进制文件 ls /usr/local/mysql/data/
//登录数据库添加数据 mysql> insert into hehe.a values(‘wang‘,‘123‘);
//生成一个新的二进制文件 mysql> flush log;
//退出数据库查看 ls /usr/local/mysql/data/
5.增量备份(需要还原的数据都在mysql-bin.000032这里)
//拷贝增加的数据 cp /usr/local/mysql/data/mysql-bin.000032 /root/
//查看/root/目录 (如以下情况已经成功备份新增加数据)
6.数据删除
//登陆数据库误删除 mysql> delete hehe.a from haha.a where user=‘lisi‘;
7.增量还原
//还原删除的新增数据mysqlbinlog mysql-bin.000018 | mysql -u root -p
//查看数据库 select * from hehe.a;
注:增量还原成功
8.验证
//登录数据库查看数据是否还原 mysql> select * from hehe.a;
注:如果做增量数据备份一定在增量前截取二进制数据,在备份完成时应再次截取二进制数据,切记一旦数据丢失所需要还原的增量数据为增量前截取的二进制数据
以上是关于MySQL的备份与还原,非常规备份,全量备份,增量备份的主要内容,如果未能解决你的问题,请参考以下文章
MySQL5.7.18 备份Mysqldump,mysqlpump,xtrabackup,innobackupex 全量,增量备份,数据导入导出