第八章 备份与恢复 阅读总结

8.1 备份与恢复概述

可以根据不同的类烈来划分备份的方法。 根据备份的方法不同可以将备份分为:

Hot Backup (热备)

Cold Backup (冷备)

Warm Backup (温备)

        Hot Backup 是指数据库运行中直接备份, 对正在运行的数据库操作没有任何的影响。 这种方式在 MySQL 官方手册中称为 Online Backup (在线备份)。 Cold Backup 是指 备份操作是在数据库停止的情况下, 这种备份最为简单, 一般只需要复制相关的数据库物理文件即可。 这种方式在 MySQL 官方手册中称为 Offline Backup (离线备份)。 Warm Backup 备份同样是在数据库运行中进行的, 但是会对当前数据库的操作有所影响, 如加 一个全局读锁以保证备份数据的一致性。

按照备份后文件的内容, 备份又可以分为:

逻辑备份

裸文件备份

        在 MySQL 数据库中, 逻辑备份是指备份出的文件内容是可读的,一般是文本文件。内容一般是由一条条SQL语句, 或者是表内实际数据组成。如mysqldump和SELECT*INTO OUTFILE 的方法。这类方法的好处是可以观察导出文件的内容, 一般适用于数据库的升级、迁移等工作。但其缺点是恢复所需要的时间往往较长。

        裸文件备份是指复制数据库的物理文件, 既可以是在数据库运行中的复制(如ibbackup、xtrabackup这类工具), 也可以是在数据库停止运行时直接的数据文件复制。这类备份的恢复时间往往较逻辑备份短很多。若按照备份数据库的内容来分, 备份又可以分为:

完全备份

增量备份

日志备份

        完全备份是指对数据库进行一个完整的备份。增抵备份是指在上次完全备份的基础上, 对于更改的数据进行备份。日志备份主要是指对MySQL数据库二进制日志的备份,通过对一个完全备份进行二进制日志的重做(replay)来完成数据库的point-in-time的恢复工作。MySQL数据库复制(replication)的原理就是异步实时地将二进制日志重做传送并应用到从(slave/standby)数据库。

8.2 冷备

        对于InnoDB存储引擎的冷备非常简单,只需要备份MySQL数据库的frm文件,共享表空间文件,独立表空间文件(*.ibd), 重做日志文件。另外建议定期备份MySQL数据库的配置文件my.cnf, 这样有利于恢复的操作。

冷备的优点是:

备份简单,只要复制相关文件即可。

备份文件易于在不同操作系统,不同MySQL版本上进行恢复。 

恢复相当简单,只需要把文件恢复到指定位嚣即可。

恢复速度快,不需要执行任何SQL语句,也不需要重建索引。

冷备的缺点是:

InnoDB存储引擎冷备的文件通常比逻辑文件大很多,因为表空间中存放着很多其他的数据,如undo段,插入缓冲等信息。

冷备也不总是可以轻易地跨平台。操作系统、MySQL的版本、文件大小写敏感和浮点数格式都会成为问题。

8.3 逻辑备份

8.3.1 mysqldump

8.3.2 SELECT…INTO OUTFILE

        SELECT. .. INTO 语句也是一种逻辑备份的方法, 更准确地说是导出一张表中的数据。

8.3.3 逻辑备份的恢复

        mysqldump的恢复操作比较简单, 因为备份的文件就是导出的SQL语句,一般只需要执行这个文件就可以了

        因为逻辑备份的文件是由SQL语句组成的, 也可以通过SOURCE命令来执行导出 的逻辑备份文件。

8.4 二进制日志备份与恢复

        二进制日志非常关键, 用户可以通过它完成 point-in-time 的恢复工作。 MySQL 数据库的 replication 同样需要二进制日志。 在默认情况下并不启用二进制日志, 要使用二进制日志首先必须启用它。

8.5 热备

8.5.1 ibbackup

        ibbackup 是 lnnoDB 存储引擎官方提供的热备工具, 可以同时备份 MylSAM 存储引擎和 InnoDB 存储引擎表。对于 InnoDB 存储引擎表其备份工作原理如下:

1) 记录备份开始时, InnoDB 存储引擎重做日志文件检查点的 LSN。

2) 复制共享表空间文件以及独立表空间文件。

3) 记录复制完表空间文件后, lnnoDB 存储引擎重做日志文件检查点的 LSN。

4) 复制在备份时产生的重做日志。

8.6 快照备份        

        MySQL数据库本身并不支持快照功能,因此快照备份是指通过文件系统支持的快照功能对数据库进行备份。备份的前提是将所有数据库文件放在同一文件分区中, 然后对该分区进行快照操作。支持快照功能的文件系统和设备包括FreeBSD的UFS文件系统,Solaris的ZFS文件系统,GNU/Linux的逻辑管理器(LogicalVolume Manager, LVM)等。这里以LVM为例进行介绍,UFS和ZFS的快照实现大致和LVM相似。

8.7 复制

8.7.1 复制的工作原理

        复制 C replication) 是 MySQL 数据库提供的一种高可用高性能的解决方案,一般用来建立大型的应用。 总体来说, replication 的工作原理分为以下 3 个步骤:

1) 主服务器 (master) 把数据更改记录到二进制日志 (binlog) 中。

2) 从服务器 (slave) 把主服务器的二进制日志复制到自己的中继日志 (relay log) 中。

3) 从服务器重做中继日志中的日志, 把更改应用到自己的数据库上, 以达到数据的最终一致性。

        复制的工作原理并不复杂,其实就是一个完全备份加上二进制日志备份的还原。不同的是这个二进制日志的还原操作基本上实时在进行中。这里特别需要注意的是,复制不是完全实时地进行同步,而是异步实时。这中间存在主从服务器之间的执行延时,如果主服务器的压力很大,则可能导致主从服务器延时较大。复制的工作原理如图8-4所示。

8.7.2 快照+复制的备份架构

        复制可以用来作为备份, 但功能不仅限于备份, 其主要功能如下:

        数据分布。 由于 MySQL 数据库提供的复制并不需要很大的带宽要求, 因此可以在不同的数据中心之间实现数据的复制。

        读取的负载平衡。通过建立多个从服务器,可将读取平均地分布到这些服务器中,并且减少了主服务器的压力。一般通过DNS的Round-Robin和Linux的LVS功能都可以实现负载平衡。

        数据库备份。复制对备份很有帮助,但是从服务器不是备份,不能完全代替备份。 

        高可用性和故障转移。通过复制建立的从服务器有助于故障转移,减少故障的停机时间和恢复时间。

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 194,670评论 5 460
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 81,928评论 2 371
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 141,926评论 0 320
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 52,238评论 1 263
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 61,112评论 4 356
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 46,138评论 1 272
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 36,545评论 3 381
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 35,232评论 0 253
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 39,496评论 1 290
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 34,596评论 2 310
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 36,369评论 1 326
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 32,226评论 3 313
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 37,600评论 3 299
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 28,906评论 0 17
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 30,185评论 1 250
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 41,516评论 2 341
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 40,721评论 2 335

推荐阅读更多精彩内容