文章详情

  • 游戏榜单
  • 软件榜单
关闭导航
热搜榜
热门下载
热门标签
php爱好者> php文档>mysql备份及恢复

mysql备份及恢复

时间:2010-07-03  来源:skybin090804

注意事项
一、确 定要备份的表的存储引擎是事务型还是非事务性,两种不同的存储引擎备份方式在处理数据一致性方面是不太一样的。
 
二、确 定使用全备份还是增量备份。全备份的优点是备份保持最新备份,恢复的时候可以花费更少的时间;缺点是如果数据量大,将会花费很多的时间,并对系统造成较长 时间的压力。增量备份则恰恰相反,只需要备份每天的增量日志,备份时间少,对负载压力也小;缺点就是恢复的时候需要全备份加上次备份到故障前的所有日志, 恢复时间会长些。
 
三、可 以考虑采取复制的方法来做异地备份,但是记住,复制不能代替备份,它对数据库的误操作也无能为力。
 
四、要 定期做备份,备份的周期要充分考虑系统可以承受的恢复时间。备份要在系统负载较小的时候进行。
 
五、确 保MySQL打开log-bin选项,有了BINLOG,MySQL才可以在必要的时候做完整恢复,或基于时间点的恢复,或基于位置的恢复。
 
六、要 经常做备份恢复测试,确保备份是有效的,并且是可以恢复的
 
 
热备份
mysqldump
介绍:mysqldump是MySQL自带的备份工具,他备份出来 的是一个文本文件可以直接查看,里面记录的就是数据库语句,原理就是通过数据库语句把数据库或表重新建了到备份时状态,其实用图形工具备份原理是一样的(都是逻辑备份)
 
 
备份
注意:一定要检查备份文件,注意 文件大小不是0,因为即使备份出错也会生成一个空文件
 
[root@zzh /]# mysqldump -u root -p --all-database > /beifeng/all.sql
备份所 以数据库,保存为all.sql文件
 
[root@zzh /]# mysqldump -u root -p zzh > /beifeng/zzh.sql
备份指 定zzh数据库,保存为zzh.sql文件
 
[root@zzh /]# mysqldump -u root -p zzh kt1 kt2 > /beifeng/biao.sql
备份zzh数据库中 的kt1和kt2表,保存为biao.sql文 件
-l参数
MyISAM存储引擎在备份的时候需要加,表示将所有表加上锁,在备份 期间,所有表将只能读而不能进行数据更新
-F参数
表示生成一个新的日志文件,这 个日志记录了之前的操作,用来完全恢复
-u参数
指定用户名
-p参数
指定密码
-h参数
指定服务器ip或者域名
-P(大写)
指定端口
 
 
完全恢复
[root@zzh /]# mysql -u root -p zzh < /beifeng/zzh.sql
恢复数据库时,数据库不受任何影响,注意:恢复的库时原库一定要存在
把数据恢复到最新状态
[root@zzh /]# mysqldump -F -u root -p kangte > /beifeng/kangte.sql
备份kangte数 据库,加-F生成一个新日志文件恢复时好查找,注意:一定要检查一下备份的文件
 
这时备份以后数据库发生的操作都会记录到二进制日志里面
 
[root@zzh /]# cp /mysqldata/mysql-bin.000009 /beifeng/
特别注意:一定要在恢复之前把日 志文件拷贝出来,否则日志也会记录恢复操作,把从备份生成后的所有二进制文件拷贝出来
 
[root@zzh /]# mysql -u root -p kangte < /beifeng/kangte.sql
执行完全恢复kangte数 据库,恢复到备份数据库时的状态,此时备份时到数据库恢复之间的操作还没有恢复
[root@zzh /]# mysqlbinlog /beifeng/mysql-bin.000009 | mysql -u root -p kangte
用二进制日志把kangte数据恢复到最新状态
 
 
不完全恢复
一、基于时间点恢复(如果00:00:00——00:30:30中间出现问题,可以跳过这段时间恢复数据)
注意:恢复数据库之前最后把二进制文件备份一下
[root@zzh /]# mysqlbinlog --stop-date="2009-09-01 00:00:00" /mysqldata/mysql-bin.000009 | mysql -u root -p kangte
用二进制日志文件把kangte数据库恢复到故障前
 
[root@zzh /]# mysqlbinlog --start-date="2009-09-01 00:30:30" /mysqldata/mysql-bin.000009 | mysql -u root -p kangte
跳过故障时间点继续恢复kangte数据库
 
二、基于位置的恢复(可以更精确的恢复数据)
[root@zzh /]# mysqlbinlog --start-date="2009-09-01 00:00:00" --stop-date="2009-09-01 00:30:30" /mysqldata/mysql-bin.000009 > /jilu.txt
根据二进制日志生成00:00:00——00:30:30中 间的操作记录文件,这里记录的是对所有数据库的操作
 
[root@zzh /]# more /jilu.txt
查看文件找出错误点前后对应的语句代号,如at 1000
 
[root@zzh /]# mysqlbinlog --stop-position="1000" /mysqldata/mysql-bin.000009 | mysql -u root -p kangte
把kangte数据 库恢复到代号为1000的语句前,注意:不恢复代号为1000的语句
 
[root@zzh /]# mysqlbinlog --start-position="1010" /mysqldata/mysql-bin.000009 | mysql -u root -p kangte
恢复代号为1010的 语句之后的语句
 
 
冷备份
直接拷贝数据库文件,根据情况备份需要备份的文件
[root@zzh /]# /usr/local/mysql/share/mysql/mysql.server stop
先关闭数据库
 
[root@zzh /]# mkdir beifeng
建立一个目录用来保存备份
 
[root@zzh /]# tar -zcvf /beifeng/2009.9.tgz ./mysqldata/
备份数据库,注意:备份时一定要 清楚自己当前所在目录,这里用的相对路径
 
[root@zzh /]# /usr/local/mysql/share/mysql/mysql.server start
启动数据库
 
用冷备份文件还原
注意:如果是一个小文件还原,直 接关闭数据库把文件复制还原回去就可以了,但是如果像全库回复,把文件拷回去时间就会很长时间,这时执行下面操作,先把文件解压到新数据库目录,修改my.cnf文 件重新指定新数据库目录,这样关闭数据库时间就会很短
[root@zzh beifeng]# mv mysqldata/ /xindata/
先把备份放到新数据库目录
 
[root@zzh /]# chown -R mysql.mysql /xindata/
给新数据库目录权限
 
 
 
[root@zzh /]# /usr/local/mysql/share/mysql/mysql.server stop
关闭数据库,注意:一定要把数据 库关闭后在修改下面的文件,要不修改完在关库会报错
 
[root@zzh /]# vim /etc/my.cnf
datadir         = /xindata
设置新数据库目录位置,注意:这个字段默认没有自己在[mysqld]标签下添加
 
[root@zzh /]# /usr/local/mysql/share/mysql/mysql.server start
排行榜 更多 +
辰域智控app

辰域智控app

系统工具 下载
网医联盟app

网医联盟app

运动健身 下载
汇丰汇选App

汇丰汇选App

金融理财 下载