通过拷贝frm myd myi opt文件来实现mysql的备份和还原

张映 发表于 2010-09-07

分类目录: mysql

标签:, , , , ,

不知道大家有没有想过,我们向mysql数据库中写入了数据,这些数据存放在什么地方。在linux下手动编译安装过mysql的人,我想会知道存放在什么地方,mysql_install_db有这一步操作,他是产生mysql自带的数据库,执行了这一步操作后,你可以到/mysql安装目录/data(这个数据目录,可以从my.cnf中查到datadir) 目录下面就会出一个mysql的文件夹。

一,frm myd myi opt的解释

1,.frm保存的是描述了表的结构

2,.MYD保存的是表的数据记录

3,.MYI保存的是表的索引 

4,.opt保存的是数据库的字符集

[root@BlackGhost test]# ls |grep opt | xargs cat
default-character-set=utf8
default-collation=utf8_general_ci

二,备份数据库

创建一个数据库,create database test;这个时候去data目录下面看看,会产生一个test文件夹,里面只有一个db.opt文件,然后你在创建一些表,添加一些数据后,你在去data/test下面看看,里面多了一些.frm,.myd的文件

tar czvf /home/databak/test.tar.gz /usr/local/mysq/data/test

这样就备份好了

三,还原数据库

1,进入test数据库

use test;
show tables;

在这儿你会看到,你新增加的表。

2,删除data/test目录下面的frm,myd,myi这三种类型的文件

use test;
show tables;

这个时候,一张表都没有。

3,还原表

tar zxvf /home/databak/test.tar.gz -C /usr/local/mysq/data

4,在查看test的表

use test;
show tables;

这个时候,新增加的表又出来了。

如果是直接把data下面的test目录删除掉的话,就重新create database test;会产生一个新的test目录,然后在把备份的数据,还原过来就行了。个人觉得这种备份比较好,导出,导入比较麻烦,不用记得备份命令,只要会copy就行了。在不改变数据库配置的前提下,这种备份,还原基本上不会出现乱码的。



转载请注明
作者:海底苍鹰
地址:http://blog.51yip.com/mysql/1005.html

1 条评论

  1. Wang Zi 留言

    还以为是灾难恢复呢? 原来是正常恢复,如果数据文件出现问题了怎么办?

    博主有没有碰到过mysql出现灾难的情况,如果有的话,还希望分享一下