1)全量备份:对数据库完整的备份
2)增量备份:从最后一次备份后改变的文件
3)差异备份:在最后一次完整后被修改的文件
建议:全量+增量=1月全量,1周增量
1)物理备份
冷备份:关闭数据后
热备份:数据运行状态时
2)逻辑备份
对逻辑对象(表、库)备份
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‘);
//关闭数据库 /etc/init.d/mysqld stop
//备份数据库 tar -zcvf /root/mysql.bak /usr/local/mysql/data/
mysqldump -u root -p --all-database >/root/mysql.sql //热备份,数据库不需停止,备份所有数据库
//误删除hehe数据库 mysql> drop database hehe;
//关闭数据库 /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
/etc/init.d/mysqld stop
//备份数据库 tar -zcvf /root/mysql.bak /usr/local/mysql/data/
mysqldump -u root -p --all-database >/root/mysql.sql //热备份,数据库不需停止,备份所有数据库
//查看二进制文件 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/
//拷贝增加的数据 cp /usr/local/mysql/data/mysql-bin.000032 /root/
//查看/root/目录 (如以下情况已经成功备份新增加数据)
//登陆数据库误删除 mysql> delete hehe.a from haha.a where user=‘lisi‘;
//还原删除的新增数据mysqlbinlog mysql-bin.000018 | mysql -u root -p
//查看数据库 select * from hehe.a;
注:增量还原成功
//登录数据库查看数据是否还原 mysql> select * from hehe.a;
注:如果做增量数据备份一定在增量前截取二进制数据,在备份完成时应再次截取二进制数据,切记一旦数据丢失所需要还原的增量数据为增量前截取的二进制数据
原文地址:http://blog.51cto.com/13043516/2112372