尤益达

一个运维狗的成长过程!

MySQL备份与还原

一、数据备份

1.备份方式

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

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

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

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

2.备份分类

1)物理备份

冷备份:关闭数据后

热备份:数据运行状态时

2)逻辑备份

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

二、完整备份

1.特性

1)数据完整

2)数据较庞大

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

方式三:(压缩锁表热备份)

//使用压缩方式来做数据库热备份
mysqldump -h localhost -uroot -p --opt --single-transaction 库名 | gzip > 库名.sql.gz

//导入数据库
gzip -dc 库名.sql.gz | mysql -uroot -p 数据库密码

注:以上热备份方式三最为安全!

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备份与还原
注:如果做增量数据备份一定在增量前截取二进制数据,在备份完成时应再次截取二进制数据,切记一旦数据丢失所需要还原的增量数据为增量前截取的二进制数据.


发表评论:

«   2020年7月   »
12345
6789101112
13141516171819
20212223242526
2728293031
搜索
控制面板
您好,欢迎到访网站!
  查看权限
标签列表
站点信息
  • 文章总数:62
  • 页面总数:1
  • 分类总数:6
  • 标签总数:17
  • 评论总数:0
  • 浏览总数:7452
最新留言
    网站收藏
    友情链接

    Powered By Z-BlogPHP 1.5.2 Zero

    Copyright cjava.net All Rights Reserved.  苏ICP备18017901号