MySQL备份与还原

MySQL备份与还原

一、数据备份

1.备份方式

1)全量备份:对数据库完整的备份

2)增量备份:从最后一次备份后改变的文件

3)差异备份:在最后一次完整后被修改的文件

建议:全量+增量=1月全量,1周增量

2.备份分类

1)物理备份

冷备份:关闭数据后

热备份:数据运行状态时

2)逻辑备份

对逻辑对象(表、库)备份

二、完整备份

1.特性

1)数据完整

2)数据较庞大

扫描二维码关注公众号,回复: 106479 查看本文章

3)时间长,重复性数据

打包、cp、mysqldump

案例:

1.准备数据

//新建hehe数据库 mysql> create database hehe;
MySQL备份与还原

//向hehe数据库添加a表和格式 mysql>create table hehe.a(user char(4),password char(8),primary key(user));
MySQL备份与还原

//插入表内数据 mysql> insert into hehe.a values('Zhangs','123');
MySQL备份与还原

//插入表内数据 mysql> insert into hehe.a values('Lisi','123');
MySQL备份与还原

2.备份

方式一:(冷备份)

//关闭数据库 /etc/init.d/mysqld stop
MySQL备份与还原

//备份数据库 tar -zcvf /root/mysql.bak /usr/local/mysql/data/
MySQL备份与还原

方式二:(热备份)

mysqldump -u root -p --all-database >/root/mysql.sql //热备份,数据库不需停止,备份所有数据库
MySQL备份与还原

3.模拟故障

//误删除hehe数据库 mysql> drop database hehe;
MySQL备份与还原

4.恢复

方式一:(冷恢复)

//关闭数据库 /etc/init.d/mysqld stop
MySQL备份与还原

//tar -zxvf /root/mysql.bak -C /
MySQL备份与还原

方式二:(热恢复)

//进入数据执行命令 mysql> source /root/mysql.sql
MySQL备份与还原

方式三:(热恢复)

//恢复数据mysql -u root -p < /root/mysql.sql
MySQL备份与还原

三、增量备份

1.Mysql不自带增量备份方式,需通过Binary logs(记录所有更改操作)实现增量

案例:

1)准备数据(同上准备数据)
MySQL备份与还原

2)开启二进制日志

//编辑MySQL数据库配置文件 vim /etc/my.cnf
MySQL备份与还原
MySQL备份与还原
MySQL备份与还原

//重启MySQL服务 /etc/init.d/mysqld restart
MySQL备份与还原

3.完整备份

方式一:(冷备份)

/etc/init.d/mysqld stop
MySQL备份与还原

//备份数据库 tar -zcvf /root/mysql.bak /usr/local/mysql/data/
MySQL备份与还原

方式二:(热备份)

mysqldump -u root -p --all-database >/root/mysql.sql //热备份,数据库不需停止,备份所有数据库
MySQL备份与还原

4.数据增加

//查看二进制文件 ls /usr/local/mysql/data/
MySQL备份与还原

//截取二进制文件准备增加数据 mysqladmin -u root -p flush-logs
MySQL备份与还原

//查看二进制文件 ls /usr/local/mysql/data/
MySQL备份与还原

//登录数据库添加数据 mysql> insert into hehe.a values('wang','123');
MySQL备份与还原

//生成一个新的二进制文件 mysql> flush log;
MySQL备份与还原

//退出数据库查看 ls /usr/local/mysql/data/
MySQL备份与还原

5.增量备份(需要还原的数据都在mysql-bin.000032这里)

//拷贝增加的数据 cp /usr/local/mysql/data/mysql-bin.000032 /root/
MySQL备份与还原

//查看/root/目录 (如以下情况已经成功备份新增加数据)
MySQL备份与还原

6.数据删除

//登陆数据库误删除 mysql> delete hehe.a from haha.a where user='lisi';
MySQL备份与还原

7.增量还原

//还原删除的新增数据mysqlbinlog mysql-bin.000018 | mysql -u root -p
MySQL备份与还原

//查看数据库 select * from hehe.a;
MySQL备份与还原
注:增量还原成功

8.验证

//登录数据库查看数据是否还原 mysql> select * from hehe.a;
MySQL备份与还原
注:如果做增量数据备份一定在增量前截取二进制数据,在备份完成时应再次截取二进制数据,切记一旦数据丢失所需要还原的增量数据为增量前截取的二进制数据

猜你喜欢

转载自blog.51cto.com/13043516/2112372
今日推荐