`

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;也就是把内存中的数据都刷新到磁盘中,同时锁定数据表,以保证拷贝过程中不会有新的数据写入。这种方法备份出来的数据恢复也很简单,直接拷贝回原来的数据库目录下即可。
分享到:
评论

相关推荐

    nbu&mysql备份恢复.docx

    NBU&MySQL备份恢复 NBU(NetBackup)是一款功能强大的备份恢复软件,而MySQL是一款流行的关系型数据库管理系统。本文将详细介绍如何使用NBU来备份和恢复MySQL数据库。 NBU备份mysql的优势 使用NBU备份mysql数据库...

    实验报告六 MYSQL备份与恢复.docx

    根据提供的实验报告“MYSQL备份与恢复”的相关内容,我们可以总结出以下几个关键知识点: ### 一、MYSQL日志管理 #### 1. 错误日志 - **定义**: 记录MySQL运行过程中的错误信息和警告信息。 - **作用**: 帮助管理...

    MySQL数据库备份和恢复

    #### 常见的MySQL备份工具与方法 MySQL提供了多种内置的备份工具和技术,主要包括: - **mysqldump**:这是最常用的数据导出工具,支持逻辑备份,即将数据表导出为SQL脚本。它可以处理不同版本间的迁移,非常适合...

    Mysql备份与恢复

    生产中Mysql备份恢复的形式,基于mysqldump备份及原理,基于Xtrabcackup备份及原理,表空间传输,binlog备份(增量),基于mysql全备+增备的恢复Tips

    MySQL 备份和恢复

    MySQL的备份和恢复是数据库管理的关键环节,确保数据的...总的来说,MySQL备份和恢复需要根据不同的表类型和需求选择合适的工具和策略。定期备份、测试恢复过程以及了解备份参数的正确使用是保证数据安全的关键步骤。

    mysql备份还原

    MySQL 备份还原是指将数据库中的数据备份到外部存储设备上,并在需要时将其恢复到数据库中。备份可以是全量备份,也可以是增量备份。全量备份是指将整个数据库的数据备份到外部存储设备上,增量备份是指将自上一个...

    mysql数据库备份与恢复

    本知识点将深入探讨如何在SpringBoot环境下对MySQL数据库进行备份与恢复,以确保数据的安全。 首先,`MysqlBackup.java` 文件很可能是实现备份和恢复功能的核心Java类。在SpringBoot中,我们可以利用JDBC(Java ...

    MySQL备份与恢复.ppt

    MySQL备份与恢复,里面都做了详细解析.ppt

    MySQL备份与恢复记录

    MySQL备份与恢复是数据库管理中的关键任务,确保数据安全和业务连续性。在本文中,我们将探讨两种主要的MySQL备份方法——冷备份和工具备份,以及如何进行恢复操作。 首先,冷备份是最简单的备份方式,它涉及在...

    Mysql数据备份与恢复操作文档.md

    ### MySQL 数据备份与恢复操作详解 #### 一、直接替换 /var/lib/mysql 文件夹 这种方法适用于需要快速替换整个 MySQL 数据库实例的情况,如系统迁移、紧急恢复等场景。但需注意,这种做法可能会导致数据不一致的...

    实验报告六MYSQL备份与恢复.doc

    此外,实验还强调了掌握MySQL备份与恢复方法的重要性。常见的备份策略包括全量备份、增量备份和差异备份。全量备份是备份全部数据,而增量备份和差异备份只备份自上次备份以来发生改变的数据。MySQL提供了多种备份...

    mysql数据库备份和恢复工具

    一、MySQL备份的重要性 数据库备份是防止数据丢失的关键步骤。无论是系统故障、硬件损坏、恶意攻击还是人为错误,都有可能导致数据丢失。定期备份可以确保在灾难发生时,能够快速恢复到正常状态,降低业务中断的影响...

    linux运维学习笔记:Mysql备份与恢复.pdf

    衡量备份恢复有两个重要的指标:恢复点目标(RPO)和恢复时间目标(RTO),前者重点关注能恢复到什么程度,而后者则重点关注恢复需要多长时间。 常用的备份方式有三种:物理备份、全量备份和增量备份。 1. 物理...

    MySQL备份及恢复方法

    ### MySQL备份及恢复方法详解 #### 一、MySQL备份的重要性 在数据库管理中,定期进行数据备份是一项至关重要的任务。数据库备份不仅可以防止因系统故障、人为错误或恶意攻击导致的数据丢失,还可以确保业务连续性...

    阿里MySQL备份恢复指南

    总的来说,阿里MySQL备份恢复指南是一份全面的资源,它将帮助用户深入了解阿里云环境下的数据库备份与恢复机制,提高数据管理和灾难恢复的能力。通过掌握这些知识,用户可以更自信地应对可能出现的数据安全挑战,...

    MySQL_Cluster备份与恢复

    在MySQL_Cluster环境中,mysqldump的使用方法与其他存储引擎相同,唯一的区别是在任意的SQL节点备份数据。 例如,在SQL节点192.168.0.70上使用mysqldump备份test库: ``` [root@192.168.0.70 ~]# mysqldump --...

    MySQL 备份和恢复策略

    MySQL 数据库的备份和恢复是数据库管理中至关重要的环节,确保数据的安全性和可恢复性。本文将探讨两种常用的 MySQL 备份策略:直接拷贝数据库文件和使用 `mysqlhotcopy` 工具。 首先,直接拷贝数据库文件是一种...

    mysql备份和恢复方案

    MySQL备份和恢复是数据库管理中的关键环节,旨在保护数据免受意外损失,如硬件故障、软件错误或数据损坏。在本方案中,我们将探讨两种主要的备份策略,并讨论如何实施有效的恢复计划,确保数据安全和应用程序的连续...

    mysql数据库的备份与恢复方法

    本篇文章将详细探讨MySQL数据库的备份与恢复方法。 一、MySQL数据库备份 1. **mysqldump工具** `mysqldump` 是MySQL提供的一个命令行实用程序,用于备份数据库结构和数据。基本语法如下: ``` mysqldump -u ...

Global site tag (gtag.js) - Google Analytics