码迷,mamicode.com
首页 > 数据库 > 详细

MySQL备份与还原

时间:2018-05-03 19:31:00      阅读:183      评论:0      收藏:0      [点我收藏+]

标签: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备份与还原

标签:MySQL   备份   还原   

原文地址:http://blog.51cto.com/13043516/2112372

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!