首页 > 编程笔记

MySQL数据库的备份和还原

数据库的备份是相当重要的,尤其是当发生数据文件损坏、MySQL 服务出现错误、系统内核崩溃、计算机硬件损坏或者数据被不小心删除等时,数据备份就可以快速解决以上所有的问题。

在 MySQL 数据库中提供了许多的备份方案,主要包括逻辑备份、物理备份、全备份以及增量备份。读者可以根据自己的需求来选择适合自己使用的方式备份数据。

1) 物理备份
物理备份是指可以直接复制包含有数据库内容的目录与文件,这种备份方式适用于对重要的大规模数据进行备份,并且要求实现快速还原的生产环境。

典型的物理备份就是复制 MySQL 数据库的部分或全部目录,物理备份还可以备份相关的配置文件。但采用物理备份需要MySQL处于关闭状态或者对数据库进行锁操作,防止在备份的过程中改变发送数据。

物理备份的方式有两种:使用 mysqlbackup 对 InnoDB 数据进行备份和使用 mysqlhotcopy 对MyISAM数据进行备份。

2) 逻辑备份
逻辑备份是指可以保存代表数据库结构及数据内容的描述信息。例如保存创建数据结构及添加数据内容的 SOL 语句。

逻辑备份适用于对少量数据的备份与还原,它需要查询 MySQL 服务器获得数据结构及内容信息,并将这些信息转换为逻辑格式,所以相对于物理备份而言比较慢。

注意,逻辑备份不会备份日志、配置文件等不属于数据库内容的资料。逻辑备份的优势在于不管是服务层面、数据库层面还是数据表层面的备份都可以实现,由于是以逻辑格式存储的,所以这种备份与系统、硬件无关。

3) 全备份
全备份主要备份某一时刻的所有数据。

4) 增量备份
增量备份是指仅备份某一段时间内发生过改变的数据。通过物理或逻辑备份工具就可以完成完全备份,但增量备份需要开启 MySQL 二进制日志,通过日志记录数据的改变,从而实现增量差异备份。

使用 mysqldump 备份所有的数据库,默认该工具会将 SQL 语句信息导出至标准输出,可以通过重定向将输出保存至文件,命令如下:

[root@bogon abc]# mysqldump --all-databases > bak.sql

备份指定的数据库,命令如下:

[root@bogon abc]# mysqldump --all-databases 数据库1 数据库2 数据库3> bak.sql

当仅备份一个数据库时,--databases 可以省略,命令如下:

[root@bogon abc]# mysqldump 数据库 > bak.sql
[root@bogon abc]# mysqldump --databases 数据库> bak.sql

注意,差别在于不使用 --databases 选项,则备份输出信息中不会包含 CREATEDATABASE 或 USE 语句。不使用 --databases 选项备份的数据文件,在后期进行数据还原操作时,如果该数据库不存在,必须先创建该数据库。


使用 mysql 命令读取备份文件,实现数据还原功能,命令如下:

[root@bogon abc]# mysql < bak.sql
[root@bogon abc]# mysql 数据库 < bak.sql

优秀文章