WEB开发网
开发学院数据库MySQL MySQL简易备份方法 阅读

MySQL简易备份方法

 2007-11-11 15:10:28 来源:WEB开发网   
核心提示: 四.如何回存 phpBB 讨论区的回存,只需把档案解回原来存放网页的路径就可以,用以下指令解开: tar xvfz phpbb2_20020601.tgz DB 发生错误而要回存时,其实也不难,先找出最近一次完整正常的备份,先把现在错误的网页或 DB 先更名或 tar 起来,再把好的备份给解开回原来目录位置就行了,需

四.如何回存

phpBB 讨论区的回存,只需把档案解回原来存放网页的路径就可以,用以下指令解开:

tar xvfz phpbb2_20020601.tgz

DB 发生错误而要回存时,其实也不难,先找出最近一次完整正常的备份,先把现在错误的网页或 DB 先更名或 tar 起来,再把好的备份给解开回原来目录位置就行了,需要注意的是, MySQL(和PHP搭配之最佳组合) 服务最好也是要先停止,回存完成後再启动服务,回存 DB 的整个程序
可能像下面:

/etc/rc.d/init.d/MySQL(和PHP搭配之最佳组合)d.stop
mv phpbb2 phpbb2_error
tar xvfz phpbb2_db_20020601.tgz
/etc/rc.d/init.d/MySQL(和PHP搭配之最佳组合)d.start

然後再去测试一下网页及资料库! 看使用上是否正常就行了...


五.MySQL(和PHP搭配之最佳组合)线上备份

使用像上面的"档案"方式备份是个不错的方法,它最少可以保持该主机某个时间点的完整档案备份,但还是有一些问题需要考虑到,有些主机就不只建立一个 DB 而已, 总不能为了备份某个 DB 而把整个 MySQL(和PHP搭配之最佳组合) 服务停止,备份档案的方式,回存在原主机上一定适用,但假如MySQL(和PHP搭配之最佳组合) 版本升级,或是在那天,该网页空间需迁机移机到别的主机时, 那就没人敢保证备出来的资料档可以用,所以我们可以考虑另一种备份的方式,是使用 MySQL(和PHP搭配之最佳组合) 本身提供的功能: "MySQL(和PHP搭配之最佳组合) Data Dump",指令是 "MySQL(和PHP搭配之最佳组合)dump".

使用 MySQL(和PHP搭配之最佳组合) 的 Dump 功能可以把 DB 的"结构","资料"或"结构加资料" Dump 成 文字档, MySQL(和PHP搭配之最佳组合)dump 指令提供的弹性很大,你可以选择把整个 DB Dump 成一个档, 或是每个 Table 为一个档,甚至是把结构档和资料分开储存都可以. 检测酷!学园的 phpBB 资料库後发现,以结构加资料 Full Dump 成一个档案, 档案的大小大约也是30几MB左右. 在 Dump 之前最好多下个 Flush-Logs 更新 LOG, 所以整个 Dump 的指令如下:

MySQL(和PHP搭配之最佳组合)admin -uroot -p flush-logs
MySQL(和PHP搭配之最佳组合)dump phpbb2 -uroot -p opt > phpbb2_20020601.sql

(phpbb2 是 DB 名称, opt 是一个使用完整 Dump 参数)

再使用 time 指令去测试执行时间,这个30几 MB 的 DB , Dump 出来竟只要15秒左右, Query 的速度还真是快,假如只是要单独 Dump 某个 Table 时,只要在上面的指令後, 转出符号 ">" 前加个 Table 名称就可以,如只要 phpbb2_users 这个 Table 的 Dump 时, 只要下:

MySQL(和PHP搭配之最佳组合)dump phpbb2 -uroot -p opt phpbb2_users > phpbb2_users_20020601.sql

Dump 出来的档案是个纯文字档,你可以用 tar 把它压起来,以上面30几 MB 的 DB 为例, 大约可以把档案大小压到1/3左右的大小,因为 Dump 出是文字档,所有的资料都是以明文 显示,所以必须注意一下备份档保存的安全性,而且建议备份档最好再另外储存於异地以及其他易於保存的媒体上,像光碟片或磁带,这样的备份才有意义.


六.MySQL(和PHP搭配之最佳组合)线上回存

若要回存整个资料库,只需将压缩的备份档还原成 Dump 的档案,再用下面的指令回存:

MySQL(和PHP搭配之最佳组合) phpbb2 -uroot -p < phpbb2_20020601.sql

这边需注意的是,若建立备份时是以"opt"或"add-drop-table"为参数时,回存的动作是先将旧的 Table 先删除,重建 Table 的结构後再把 Data 汇入,所以回存後, 所有的资料会回到你当时备份那个时间点,因此在回存资料时,可以考虑把现有错误或不完整的 DB 先备份一份下来,以备不时之需,或是拿来比对错误的地方在那里,当然你也可以把资料回存到另一个测试用的 DB 内,只要把上面指令的 DB 名称改成你的测试用 DB 名称即可.

使用这种回存方式, MySQL(和PHP搭配之最佳组合) 服务不需停止,也不会动到其他正在使用的 DB ,在一些提供MySQL(和PHP搭配之最佳组合) 服务的虚拟主机,可用这种方式作你自己的 DB 备份及回存.

另外,假如你是系统重建或是移机时,切需在新的 MySQL(和PHP搭配之最佳组合) 内,新建一个空白 DB 後,才行作回存的工作,你可以用下面的指令建立:

MySQL(和PHP搭配之最佳组合) -uroot -p -e "CREATE DATABASE phpbb2"

(上面的phpbb2是你要新建的 DB 名称)

另一种作法,先用 "MySQL(和PHP搭配之最佳组合)" 指令进入 "MySQL(和PHP搭配之最佳组合) client console", 然後再用:

CREATE DATABASE phpbb2;

这样就行了,记得尾端要加个 ";" 符号该行指令才会执行.

Tags:MySQL 简易 备份

编辑录入:coldstar [复制链接] [打 印]
赞助商链接