Mysql备份与恢复方法

Mysql备份与恢复方法(一)2010-06-12 10:04摘要

本文详细分析 MySQL 的备份和恢复机制,以及如何维护数据表,包括最主要的两种表类型:MyISAM 和 Innodb,文中设计的 MySQL 版本为 5.0.22。

目前 MySQL 支持的免费备份工具有:mysqldump、mysqlhotcopy,还可以用 SQL 语法进行备份:BACKUP TABLE 或者 SELECT INTO OUTFILE,又或者备份二进制日志(binlog),还可以是直接拷贝数据文件和相关的配置文件。MyISAM 表是保存成文件的形式,因此相对比较容易备份,上面提到的几种方法都可以使用。Innodb 所有的表都保存在同一个数据文件 ibdata1 中(也可能是多个文件,或者是独立的表空间文件),相对来说比较不好备份,免费的方案可以是拷贝数据文件、备份 binlog,或者用 mysqldump。

1. mysqldump(完全备份)
2. mysqlhotcopy

3. SQL语法备份

4.启动二进制日志(增量备份)

(1)指定恢复时间

(2)指定恢复位置

5.直接拷贝数据文件和相关的配置文件

1 mysqldump

1.1备份

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

通常使用以下 SQL 来备份 MyISAM 表:
在cmd命令下,使用mysql –u root –p(mysql -u 用户名(默认为root) -p(密码));语句进入mysql,show databases----查看数据库,选择要备份的数据库。

按exit退出后,使用语句:

"mysqldump –u 用户名 –p 密码 数据库名>路径:导出的文件名"

如下:

mysqldump –u root –p huang[db_name]>huang[db.name].sql(或者huang.txt)备份数据库:

1.2 还原
  用 mysqldump备份出来的文件是一个可以直接倒入的 SQL 脚本,有两种方法可以将数据导入。
  直接用 mysql 客户端

语句为:"mysql –u 用户名 –p 要导入数据的数据库名<路径:导入的文件名"

如下:
  mysql –u root –p text[db_name ]< huang[db_name].sql(huang.txt)

重新创建一个新的数据库text,将huang.sql导入:

用 SOURCE 语法

创建一个新的数据库shuju:

进入数据库shuju,用source语句导入所要导入的数据:

这里需要指定文件的绝对路径,并且必须是 mysqld 运行用户

语法为:"mysql>source +绝对路径",

如:mysql>source c:\huang.sql 



Mysql备份与恢复方法(二)2010-06-12 10:062、 mysqlhotcopy
  2.1 备份
  mysqlhotcopy 是一个 PERL 程序,最初由Tim Bunce编写。它使用 LOCK TABLES、FLUSH TABLES 和 cp 或 scp 来快速备份数据库。它是备份数据库或单个表的最快的途径,但它只能运行在数据库文件(包括数据表定义文件、数据文件、索引文件)所在的机器上。mysqlhotcopy 只能用于备份 MyISAM,并且只能运行在 类Unix 和 NetWare 系统上。
  mysqlhotcopy 支持一次性拷贝多个数据库,同时还支持正则表达。以下是几个例子:
  root#/usr/local/mysql/bin/mysqlhotcopy -h=localhost -u=yejr -p=yejr db_name /tmp
  (把数据库目录 db_name 拷贝到 /tmp 下)
 root#/usr/local/mysql/bin/mysqlhotcopy -h=localhost -u=yejr -p=yejr db_name_1 ...
  db_name_n /tmproot#/usr/local/mysql/bin/mysqlhotcopy -h
  =localhost -u=yejr -p=yejr db_name./regex/ /tmp
  更详细的使用方法请查看手册,或者调用下面的命令来查看 mysqlhotcopy 的帮助:
  perldoc /usr/local/mysql/bin/mysqlhotcopy
  注意,想要使用 mysqlhotcopy,
  必须要有 SELECT、RELOAD(要执行 FLUSH TABLES) 权限,并且还必须要能够有读取 datadir/db_name 目录的权限。
  2.2 还原
 mysqlhotcopy备份出来的是整个数据库目录,使用时可以直接拷贝到 mysqld 指定的 datadir (在这里是 /usr/local/mysql/data/)目录下即可,同时要注意权限的问题,如下例:
  root#cp -rf db_name /usr/local/mysql/data/root#chown -R nobody:nobody /usr/local/mysql/data/
  (将 db_name 目录的属主改成 mysqld 运行用户)

3、 SQL 语法备份
  3.1 备份
(1)BACKUP TABLE
  BACKUP TABLE 语法其实和 mysqlhotcopy 的工作原理差不多,都是锁表,然后拷贝数据文件。它能实现在线备份,但是效果不理想,因此不推荐使用。它只拷贝表结构文件和数据文件,不同时拷贝索引文件,因此恢复时比较慢。例子:
  BACK TABLE tbl_name TO '/tmp/db_name/';
  注意,必须要有 FILE 权限才能执行本SQL,并且目录 /tmp/db_name/ 必须能被 mysqld 用户可写,导出的文件不能覆盖已经存在的文件,以避免安全问题。

(2)SELECT INTO OUTFILE

  SELECT INTO OUTFILE 则是把数据导出来成为普通的文本文件,可以自定义字段间隔的方式,方便处理这些数据。(只用于备份表数据???)如:

"Select * into outfile ‘文件名’ from 表格名" 如下:

Select * into outfile ‘[file.name]’ from tab.name;

注意,必须要有 FILE 权限才能执行本SQL,并且文件 /tmp/db_name/tbl_name.txt 必须能被 mysqld 用户可写,导出的文件不能覆盖已经存在的文件,以避免安全问题。

3.2 恢复
(1)BACKUP TABLE
  用 BACKUP TABLE 方法备份出来的文件,可以运行 RESTORE TABLE 语句来恢复数据表。例子: RESTORE TABLE FROM '/tmp/db_name/';权限要求类似上面所述。

(2)SELECT INTO OUTFILE
  用 SELECT INTO OUTFILE 方法备份出来的文件,可以运行 LOAD DATA INFILE 语句来恢复数据表。例子:
  LOAD DATA INFILE '/tmp/db_name/tbl_name.txt' INTO TABLE tbl_name;
  权限要求类似上面所述。倒入数据之前,数据表要已经存在才行。如果担心数据会发生重复,可以增加 REPLACE 关键字来替换已有记录或者用 IGNORE 关键字来忽略他们。


Mysql备份与恢复方法(三)2010-06-12 10:074、启动二进制日志

采用 binlog 的方法相对来说更灵活,省心省力,而且还可以支持增量备份。

1 通过show variables like 'log_bin'查看二进制日志是否启动

2 手动设置set @@log_bin=on;

或先关闭mysql服务,在配置文件my.cnf加入server-id = 1 log-bin = binlog log-bin-index = binlog.index,然后启动mysql服务

运行过程中会产生 binlog.000001 以及 binlog.index,前面的文件是 mysqld 记录所有对数据的更新操作,后面的文件则是所有 binlog 的索引,都不能轻易删除。

3 show binlog events查看二进制日志文件 进行一些数据操作, 再用show binlog events 看看二进制日志文件的变化

需要备份时,可以先执行一下 SQL 语句,让 mysqld 终止对当前 binlog 的写入,就可以把文件直接备份,这样的话就能达到增量备份的目的了: FLUSH LOGS;如果是备份复制系统中的从服务器,还应该备份 master.info 和 relay-log.info 文件。

4 mysqlbinlog --start-position=4 --stop-position=477 jian-pc.000001 > c:\\test1.txt 用mysqlbinlog导出二进制日志文件

5 mysqlbinlog语句中通过--start-date和--stop-date选项指定DATETIME格式的起止时间

mysqlbinlog --start-date="2009-04-10 17:30:05" --stop-date="2009-04-10 17:41:28" jian-pc.000001> c:\\test1.txt

6 进入mysql导入 source c:\\test1.txt

7 查看数据是否恢复

5、 直接备份数据文件
相较前几种方法,备份数据文件最为直接、快速、方便,缺点是基本上不能实现增量备份。为了保证数据的一致性,需要在靠背文件前,执行以下 SQL 语句: FLUSH TABLES WITH READ LOCK;也就是把内存中的数据都刷新到磁盘中,同时锁定数据表,以保证拷贝过程中不会有新的数据写入。这种方法备份出来的数据恢复也很简单,直接拷贝回原来的数据库目录下即可。
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值