数据库备份大揭秘:30种常用备份方法盘点 (常用数据库备份方法)

随着企业业务量的不断扩大以及数据的不断增长,数据备份变得越来越重要。最常用的备份方式是数据库备份,当然,备份数据库也可以有多种方法。本文将介绍30种常用的数据库备份方法,帮助您选择适合您的业务需求的备份方法。

1. 完全备份

完全备份是将整个数据库备份的一种方式。使用此方法备份的文件包含数据库的每个数据表和每个表中的数据。

2. 差异备份

差异备份只备份了上次完全备份后更改的数据。这样可以减少备份文件的大小和时间。

3. 增量备份

增量备份是与差异备份相似的,只备份从上次备份以来发生更改的数据。但是,在一段时间内需要多次增量备份时,其备份文件的大小会变得非常大。

4. 日志备份

日志备份是数据库记录的所有事务操作的记录。这也是恢复数据库的一种方式。

5. 复制备份

复制备份会将数据库复制到另一个位置。这种备份方法可用于创建生产数据库的完全副本,从而提供远程故障恢复。

6. 热备份

热备份指在数据库运行期间进行的备份。热备份可确保数据可用性,但它需要更高的技术和硬件能力。

7. 冷备份

冷备份是在数据库不活动时进行的备份。这种备份方法需要关闭数据库,但更便于管理。

8. 在线备份

在线备份是在数据库运行期间进行的备份。在线备份可以保证数据完整性,但需要更高的技术和硬件能力。

9. CLI备份

CLI备份是通过命令行界面进行备份的。它可以在多个平台上运行并支持自动化。

10. GUI备份

GUI备份是通过图形用户界面进行备份的。它更容易使用,但需要更高的技术和硬件能力。

11. 远程备份

远程备份是将数据库备份到远程位置的一种备份方法。这种备份方法可用于远程故障恢复。

12. 本地备份

本地备份是将数据库备份到本地位置的备份方法。本地备份通常比远程备份更快,但不如远程备份灵活。

13. 定时备份

定时备份是自动备份数据库的一种方法。这种备份方法可确保数据始终是最新的。

14. 手动备份

手动备份是需要手动执行的备份方法。这种备份方法是最容易理解的备份方式之一,因为它可以确保数据完整性。

15. 自动备份

自动备份是在特定条件下自动执行的备份方法。这种备份方法可以减少人工错误。

16. 本地备份到远程

本地备份到远程是将数据库备份到远程位置并将其存储在本地位置的方法。这种备份方法可用于远程故障恢复。

17. 远程备份到本地

远程备份到本地是将数据库备份复制到本地位置的备份方法。这种备份方法更好地保护了数据,并且可用于本地故障恢复。

18. 磁盘备份

磁盘备份是将数据库备份到硬盘驱动器的一种备份方法。这种备份方法比其他方法更快,但也更容易受到硬件故障的影响。

19. 网络备份

网络备份是将数据库备份到远程服务器的一种备份方法。这种备份方法可以通过网络传输大量数据,但也更容易受到网络故障的影响。

20. 站点备份

站点备份是将备份文件存储在物理位置的备份方法。这种备份方法可以提供保护,因为它存储文件的位置更容易管理。

21. 数字备份

数字备份是将数据库备份存储在数字媒体上的一种备份方法。这种备份方法可以保证数据安全性,并且通常比其他方法更方便。

22. 原始备份

原始备份是从原始设备重新创建数据库的备份方法。这种备份方法可用于恢复数据,但不是常见的备份方法。

23. 条带备份

条带备份是将备份文件分成小块的备份方法。这种备份方法可以降低恢复时间,并且通常在需要交换备份数据时使用。

24. 全部恢复

完全恢复是恢复整个数据库的方法。这种方法需要完全备份作为起点。

25. 差异恢复

差异恢复是只恢复自上次完全备份以来更改过的数据的方法。这种恢复方法使用差异备份的方法。

26. 增量恢复

增量恢复是只恢复从上次备份以来更改过的数据的方法。这种恢复方法使用增量备份的方法。

27. 事务恢复

事务恢复是恢复事务日志的方法。这种恢复方法可以恢复被错误处理的事务。

28. 数据库复制

数据库复制是复制数据库到另一个位置的备份方法。这种备份方法可用于创建生产数据库的完全副本。

29. 数据库迁移

数据库迁移是将数据库从一个位置移动到另一个位置的方法。这种备份方法通常用于重新安排数据集并更改存储位置。

30. 数据库同步

数据库同步是将多个数据库相互同步进行更新的方法。这是企业应用程序中常见的备份方法。

使用正确的备份方法可以确保数据安全,减少数据丢失的风险,并帮助公司遵守监管标准。请选择适合您业务需求的备份方法并确保数据安全。

相关问题拓展阅读:

mysql数据库备份的几种方法

一,搭建主从架构,master-slave,亩孝通过binlog文件同步复制主库的数据,也可以直接通过binlog文件恢复数据。

二,通过系统计划任务执行mysqldump做周期性全备份。吵耐蠢

三,物理备份,直接拷贝数据文件、参数文件、日志文件。

这些是我所熟悉的一些备份方案,

还有就是有些升陪专门的备分工具,比如说mysqlhotcopy(尽限myisam),ibbackup(innodb)等等。

数据备份是数据容灾的最后一道防线,即便有着两地三中心的架构,备份也依然重要。如果备份出问题,备份时影响了交易业务,备份数据无法恢复,这些也是企业难以承受的。所以选择合适的备份工具尤为重要。

每个企业级数据库都会有配套的备份工具,MEB(MySQL Enterprise Backup)就是MySQL企业版中非常重要的工具之一,是为企业级客户提供的数据备份方案。

Xtrabackup一直作为MEB 开源版备胎而存在,从MySQL 8.0开始情况可能会变得有所不同。

在 MySQL 8.0的Backup Lock、Redo Log Archiving、Page Tracking等新特性的加持下,MEB备毁敏份/恢复体验会更好,目前xtrabackup还不支持这些特性。

MySQL 企业版还有哪些功能?

特性1:Backup Lock

8.0之前使用xtrabackup或MEB做物理备份,为了保证备份时InnoDB引擎表与其他引擎数据文件、及binlog日志的一致性会上全局读锁,再拷贝非InnoDB文件,这期间MySQL会变成只读,数据无法写入。表数量越多,可能加上时间越长,如果使用的xtrabackup 不小心没加rsync参数,逐个拷贝frm文件,锁定时间会更长,对业务影响较大。

我曾遇到过部署在虚拟机的实例有12023多张表,当时使用的xtrabackup,备份脚本中没加rsync参数,结果锁了十几分钟,而MEB就没有这样的问题。

MySQL 8.0支持轻量级备份锁 LOCK INSTANCE FOR BACKUP,数据字典也重构了由InnoDB存储。若不创建非InnoDB表,MEB默认使用备份锁获取binlog日志一致性位置,并阻止DDL操作,但不影响DML操作。

只有InnoDB表,仅上备份锁

请点击输入图片描述

若有非InnoDB表,上全局锁

请点击输入图片描述

特性2:Redo Log Archiving

MEB能做到在线热备,备份时不影响数据库读写,这是利用了InnoDB事务日志,在备份期间持续监视redo log的变化,读取增量变化,写入到ibbackup_logfile,也就不需要上锁棚雀来保障备份一致性。(对非InnoDB的文件需要上读锁拷贝)

如果备份期间数据库写入负载特别大,而写入ibbackup_logfile速度较慢,redo log size也不大,很可能会出现ibbackup_logfile的写入速度跟不上redo log记录生成速度,redo log 空间不够时需要覆写日志文件,那么来不及写入ibbackup_logfile的记录会丢失,导致备份失败。

MEB 4.1对此做了优化,将redo log处理线程拆分成多线程分工合作,提高处理redo log的效率,降低了redo log覆写造成备份失败的概率,但redo log新增速度和ibbackup_logfile写入速度悬殊太大,问题依然会发生。

MySQL 8.0.17支持了redo log archiving 彻底解决了此问题,备份前设置innodb_redo_log_archive_dirs,指定redo log归档目录。MEB备份时自动开启日志归档,当checkpoint时会将旧记录归档到此目录,后续从归档文件中读取redo日志记录,避免了覆写可能导致的redo记录丢失。

请点击输入图片描述

注意:innodb_redo_log_archive_dirs 不能在数据目录下,目录权限要求是700

特性3:Page Tracking

Page Tracking 是为优化增量备份效率,减少不必要的数据页扫描。

增量备份当前有3种扫描模式:

page-track:利用LSN精确跟踪上次备份之后被修改页面,仅复制这些页面,效率最快。

optimistic:扫描上次备份之后被修改的InnoDB 数据文件中,找出并拷贝修改的页面。依赖系统时间,使用存在限制。

full-scan:扫描所有InnoDB数据文件,找出并拷贝自上次备份之后修改的页面,效率最慢

1、利用page-track增量备份,需先安装备份组件

mysql> INSTALL COMPONENT “

2、在全备前开启page-track

SELECT mysqlbackup_page_track_set(true);

3、全备之后,做增量备份时指定若满足page tracking条件,默认会使用page-track模式,否则会使用full-scan模式,也可以指定–incremental=page-track。

mysqlbackup –incremental-backup-dir=backup_incr –trace=3 –incremental=page-track –incremental-base=history:last_full_backup backup

incremental-base有3种选择

last_backup:基于前一次备份做增备,前一次备份可能是增备,也可能是全备。这种方式全备之间可能会有多个增备,每次增量可能比较小,但恢复时需要逐个合并。

last_full_backup:基于前一次全备做增备。这种方式增备会越往后体积可能越大,但恢复时只需要合并最后一次增量备份。

dir:基于前一次的备份目录,前一次备份可能是增备,也可能是全备。

测试对比full-scan 和page-track ,在变更页小于总体50%的情况下 ,备份效率至少能有1倍的速度提升。

page-track 模式 磁盘读写均衡,说明读写的都是修改页面。

请点击输入图片描述

full-scan模式 磁盘读写差别很大,说明读了很多未修改的页面。

请点击输入图片描述

关于常用数据库备份方法的介绍到此就结束了,不知道你从中找到你需要的信息了吗 ?如果你还想了解更多这方面的信息,记得收藏关注本站。


数据运维技术 » 数据库备份大揭秘:30种常用备份方法盘点 (常用数据库备份方法)