为了账号安全,请及时绑定邮箱和手机立即绑定

MySQL数据库的备份和还原的详述

标签:
Linux

数据库的备份是相当重要的,尤其是当发生数据文件损坏、MySQL 服务出现错误、系统内核崩溃、计算机硬件损坏或者数据被不小心删除等时,数据备份就可以快速解决以上所有的问题。下面良许小编将MySQL数据库的备份和还原进行详述,希望对大家有所帮助。

Linux命令

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

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

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

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

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

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

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

  1. 全备份
    全备份主要备份某一时刻的所有数据。

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

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

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

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

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

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

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

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

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

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

点击查看更多内容
TA 点赞

若觉得本文不错,就分享一下吧!

评论

作者其他优质文章

正在加载中
  • 推荐
  • 评论
  • 收藏
  • 共同学习,写下你的评论
感谢您的支持,我会继续努力的~
扫码打赏,你说多少就多少
赞赏金额会直接到老师账户
支付方式
打开微信扫一扫,即可进行扫码打赏哦
今天注册有机会得

100积分直接送

付费专栏免费学

大额优惠券免费领

立即参与 放弃机会
意见反馈 帮助中心 APP下载
官方微信

举报

0/150
提交
取消