Linux下Mysql数据库备份和恢复

本文介绍了MySQL数据库的几种备份方法,包括使用mysqldump命令进行SQL级别备份、利用SOURCE语法直接导入备份文件以及mysqlhotcopy工具实现快速备份。文中详细解释了每种方法的具体操作步骤及注意事项。

mysqldump -uroot -pnntv tidemedia_cms > /data/test.sql


一、 使用mysql相关命令进行简单的本地备份


    1 mysqlldump命令

    mysqldump 是采用SQL级别的备份机制,它将数据表导成 SQL 脚本文件,在不同的 MySQL 版本之间升级时相对比较合适,这也是最常用的备份方法。

    使用 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
    上面的命令会备份articles, comments, 和links 三个表。

    恢复数据使用命令:
#mysql –u -p db_backup </usr/backups/mysql/ db_backup2008-1-6.sql
    注意使用这个命令时必须保证数据库正在运行。

    2 使用 SOURCE 语法

    其实这不是标准的 SQL 语法,而是 mysql 客户端提供的功能,例如:
# SOURCE /tmp/db_name.sql;
    这里需要指定文件的绝对路径,并且必须是 mysqld 运行用户(例如 nobody)有权限读取的文件。

    3 mysqlhotcopy备份

    mysqlhotcopy 只能用于备份 MyISAM,并且只能运行在 linux 和Unix 和 NetWare 系统上。mysqlhotcopy 支持一次性拷贝多个数据库,同时还支持正则表达。以下是几个例子:
#mysqlhotcopy -h=localhost -u=goodcjh -p=goodcjh db_name /tmp
    (把数据库目录 db_name 拷贝到 /tmp 下)
    注意,想要使用 mysqlhotcopy,必须要有 SELECT、RELOAD(要执行 FLUSH TABLES) 权限,并且还必须要能够有读取 datadir/db_name 目录的权限。

    还原数据库方法:

    mysqlhotcopy 备份出来的是整个数据库目录,使用时可以直接拷贝到 mysqld 指定的 目录 (在这里是 /usr/local/mysql/data/)目录下即可,同时要注意权限的问题,另外首先应当删除数据库旧副本如下例:

# /bin/rm -rf /mysql-backup/*old
    关闭mysql 服务器、复制文件、查询启动mysql服务器的三个步骤: 
# /etc/init.d/mysqld stop Stopping MySQL: [ OK ] # cp -af /mysql-backup/* /var/lib/mysql / # /etc/init.d/mysqld start Starting MySQL: [ OK ] #chown -R nobody:nobody /usr/local/mysql/data/ (将 db_name 目录的属主改成 mysqld 运行 用户)
转载自http://server.it168.com/server/2008-01-27/200801271649470.shtml
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值