我的编程空间,编程开发者的网络收藏夹
学习永远不晚

Facebook中怎么做MySQL备份

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

Facebook中怎么做MySQL备份

Facebook中怎么做MySQL备份,很多新手对此不是很清楚,为了帮助大家解决这个难题,下面小编将为大家详细讲解,有这方面需求的人可以来学习下,希望你能有所收获。

  Facebook是怎么做MySQL备份的

  从mysqldump到Xtrabackup

  我们使用mysqldump来进行每日的数据库备份,mysqldump对数据进行逻辑备份,就像应用访问数据库那样,mysqldump以SQL语句的方式从数据库中读取一张张表,将表结构和数据转保存到文该篇文章件.mysqldump最大的问题是速度太慢(对于我们的一些大的数据库,通常要花24小时,甚至更久),并且以SQL语句的方式读取数据可能造成磁盘的随机读,这就会造成主机的load增大,影响性能.对于时间太长,我们可以跑多个实例来并发的做备份,这能缩短备份的时间,但是会造成更多的load,更影响主机的性能.

  另外一个可行的备份方式是进行物理备份(我们称之为二进制备份,binarybackup),通过操作系统层面,读取数据库磁盘文件,而非通过SQL语句.这样的话在备份的过程中,数据不能像SQL读取的时候保持事务上一致的.只有当备份的数据文件在数据库里复原了,他们才又一致了,这类似于数据库down掉之重启一样.

  我们通过修改增强Xtrabackup来满足我们额外的需求:

  1.支持快速的表级还原

  2.增强全量和增量备份

  3.支持混合增量备份

  Xtrabackup支持增量备份,也就是备份自上次全量备份后改变的数据.这样我们就能够减少备份的空间(比如每天一次增量备份,每周一次全量备份).Xtrabackup也支持多级增量备份,不过我们不使用,避免复杂.

  Facebook是怎么做MySQL备份的

  1.表级还原

  我们写了一个PHP脚本,来从二进制备份文件中读取并还原指定的表.当前,这个脚本还不能自己从备份文件中读取信息创建表结构,因此必须事先准备好一个对应的空的表.我们对Xtrabackup也做了相应的修改来支持这个工具.这个修改就是支持Xtrabackup导入导出单表.单表的还原比全量还原快得多,因为只需要从文件中读取相应的表的信息.

  2.调整全量和增量复制

  fb是Xtrabackup早期的增量备份功能的用户,起初对于一些有大量表的数据库,Xtrabackup的增量备份不起作用.后来我们和percona一起解决了这些问题.

  Xtrabackup只有本地增量备份功能,也就是说增量备份的文件必须要和MySQL在同台主机上.我们修改使之支持远程增量备份,也就是通过类似管道的方式将备份的数据同时发送到远程主机,.如果先在本地做增量备份,然后通过网络传到远程主机,对我们来说是不可取的,因为会大大增加本地的写操作.

  Xtrabackup以1MB为1个chunk来读取数据库文件,我们发现使用8MB时,能够使增量备份的速度快一倍,使全量备份快40%.

  3.让增量备份成为真正的增量

  Xtrabackup的增量备份读取数据库的每个page,来判断哪些page改变了.我们创建了一个page追踪器,通过读取事务日志,并且通过每个表的bitmap,来追踪修改过的page,.这样我们就能很好的追踪哪些page改变了哪些没变,我们就可以只读取那些改变过的page.我们称这位真正的增量备份.

  不过讽刺的是,我们发现这种真正的增量备份比普通的增量备份反而来的慢..这是因为普通的增量备份用8MB的chunk来读取文件,而真正的增量备份读取文件的大小是不定的,从16KB(INNODB中一个page的大小)到8MB,这取决于有多少连续的page是被修改过的.因此在我们的很多场景下(自上次全量备份后大概10%-30%的page修改了),真正的增量备份比普通的增量备份花了更多的IO调用.

  因为我们进行了改进,有了一种混合增量的备份,通过避免读取未修改的page来减少IO次数,在我们的场景下,这种混合增量备份减少了20%-30%的IO,IO的大小从16KB到8MB不等.

  下表描述了使用上述改进的方法来处理大概750GB数据时产生的不同结果.由于mysqldump速度的原因,mysqldump只在少数几个数据库上跑,我们使用gzip来对mysqldump的结果进行压缩,很慢,但是压缩率很高.

  QPress用来压缩二进制备份,它比gzip快多了,但是压缩效率更低.由于我们经常作增量备份,较少作全量备份,整个二进制备份所需要的空间和mysqldump所需要的空间还是差不多的。

看完上述内容是否对您有帮助呢?如果还想对相关知识有进一步的了解或阅读更多相关文章,请关注亿速云行业资讯频道,感谢您对亿速云的支持。

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

Facebook中怎么做MySQL备份

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

mysql主从备份如何做

在MySQL中,主从备份是一种常用的备份策略,通过主从复制实现数据的实时同步。下面是主从备份的步骤:配置主从复制:首先需要在主服务器和从服务器上配置主从复制。在主服务器上设置binlog日志,然后在从服务器上配置连接主服务器并读取binlo
mysql主从备份如何做
2024-05-06

oracle怎么做数据库备份

在Oracle数据库中,可以使用以下方法来进行数据库备份:使用RMAN(Recovery Manager)工具进行备份:RMAN是Oracle官方提供的备份和恢复工具,可以通过RMAN命令行或图形界面来进行数据库备份。可以使用RMAN来备份
oracle怎么做数据库备份
2024-04-22

linux系统怎么做全盘备份

在Linux系统中,可以使用工具如tar、rsync和dd等来进行全盘备份。1. 使用tar命令进行备份:```tar -cvpzf backup.tar.gz --exclude=/proc --exclude=/lost+found -
2023-10-07

linux怎么做全盘数据备份

要在Linux系统上进行全盘数据备份,您可以使用一些工具和方法。下面是一种常见的方法:使用rsync命令备份数据:打开终端并输入以下命令:sudo rsync -aAXv --delete --exclude=/dev/* --exclud
2023-10-24

MySQL数据备份中mysqldump怎么用

这篇文章主要介绍了MySQL数据备份中mysqldump怎么用,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。 一、mysqldump 简介mysqldump 是 MySQL
2023-06-25

centos中怎么备份mysql数据库

本篇内容介绍了“centos中怎么备份mysql数据库”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!代码如下:#!/bin/bash#bac
2023-06-09

怎么在linux中定时备份mysql

怎么在linux中定时备份mysql?很多新手对此不是很清楚,为了帮助大家解决这个难题,下面小编将为大家详细讲解,有这方面需求的人可以来学习下,希望你能有所收获。什么是Linux系统Linux是一种免费使用和自由传播的类UNIX操作系统,是
2023-06-09

linux中mysql怎么备份shell脚本

本篇内容主要讲解“linux中mysql怎么备份shell脚本”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“linux中mysql怎么备份shell脚本”吧!第一步:在你的linux服务器中定义
2023-06-09

编程热搜

目录