Linux系统下备份MySQL数据库操作

很多用户都有过丢失宝贵数据的经历,随着大量的数据被存入到MySQL数据库中,再加上错误地使用DROP DATABASE命令、系统崩溃或对表结构进行编辑等操作,都可能酿成灾难性的损失。所以对MySQL数据库进行备份,以备在出现意外时及时进行恢复是非常必要的。
7 k }# p; a* Z+ T4 ]/ _ u6 f
一、 使用mysql相关命令进行简单的本地备份
1 mysqlldump命令 4 D) l5 c; x6 i6 W, H3 z
mysqldump 是采用SQL级别的备份机制,它将数据表导成 SQL 脚本文件,在不同的 MySQL 版本之间升级时相对比较合适,这也是最常用的备份方法。 7 }0 P* ^: [6 `& C0 q m
使用 mysqldump进行备份非常简单,如果要备份数据库” db_backup ”,使用命令:
#mysqldump –u -p phpbb_db_backup > /usr/backups/mysql/db_backup2008-1-6.sql
还可以使用gzip命令对备份文件进行压缩:
#mysqldump db_backup | gzip > /usr/backups/mysql/ db_backup2008-1-6.sql.gz
只备份一些频繁更新的数据库表:
## mysqldump sample_db articles comments links > /usr/backups/mysql/sample_db.art_comm_lin.2008-1-6.sql " ~1 J( ]6 e7 b6 a9 k9 c+ T
上面的命令会备份articles, comments, 和links 三个表。 7 l# L8 k: J( |# p4 L! C7 m9 C
恢复数据使用命令:
#mysql –u -p db_backup </usr/backups/mysql/ db_backup2008-1-6.sql ; V5 u, V- l8 R- o3 d( ^" m
注意使用这个命令时必须保证数据库正在运行。
2 使用 SOURCE 语法 ; t# r/ ? y z3 N2 I. R' n
其实这不是标准的 SQL 语法,而是 mysql 客户端提供的功能,例如:
# SOURCE /tmp/db_name.sql;
这里需要指定文件的绝对路径,并且必须是 mysqld 运行用户(例如 nobody)有权限读取的文件。 ( r B; a9 Q+ O% c; g
) }- i7 N. `: t( S- ^$ m
3 mysqlhotcopy备份
mysqlhotcopy 只能用于备份 MyISAM,并且只能运行在 linux 和Unix 和 NetWare 系统上。mysqlhotcopy 支持一次性拷贝多个数据库,同时还支持正则表达。以下是几个例子: 2 }8 m6 {" q6 s) [9 ]
#mysqlhotcopy -h=localhost -u=goodcjh -p=goodcjh db_name /tmp
(把数据库目录 db_name 拷贝到 /tmp 下)
注意,想要使用 mysqlhotcopy,必须要有 SELECT、RELOAD(要执行 FLUSH TABLES) 权限,并且还必须要能够有读取 datadir/db_name 目录的权限。 . ]; O" @! j/ v4 q2 s) }6 n
还原数据库方法:9 E2 T2 y% u4 S' g
! H; Z% i7 Q4 K* P- ?; r& G% ?, X2 D! F
mysqlhotcopy 备份出来的是整个数据库目录,使用时可以直接拷贝到 mysqld 指定的 目录 (在这里是 /usr/local/mysql/data/)目录下即可,同时要注意权限的问题,另外首先应当删除数据库旧副本如下例:
# /bin/rm -rf /mysql-backup/**//*old
关闭mysql 服务器、复制文件、查询启动mysql服务器的三个步骤: 3 r% g U& |* E$ f( B( f6 A, I
# /etc/init.d/mysqld stop" Z! C7 X5 ]& H: J4 l$ y
Stopping MySQL: [ OK ]
# cp -af /mysql-backup/**//* /var/lib/mysql /
# /etc/init.d/mysqld start9 `6 N& [+ E5 Y, h3 ]
Starting MySQL: [ OK ]$ p6 K: V- q1 o* V8 K# |
#chown -R nobody:nobody /usr/local/mysql/data/ (将 db_name 目录的属主改成 mysqld 运行用户)
转载网址:http://tech.techweb.com.cn/thread-229688-1-1.html
Tags: 

延伸阅读

最新评论

发表评论