数据库备份和恢复
dbmsdatabasemysql
必须备份数据库,以防原始数据库因任何原因损坏或丢失。使用此备份,数据库可以恢复到故障前的状态。
数据库备份基本上意味着创建数据库信息和数据的副本并将其存储在备份服务器中,以防万一。事务日志也与数据库数据一起存储在备份中,因为没有它们,数据将毫无用处。
数据库故障的原因
数据库故障的原因可能有很多,因此需要制定数据库备份和恢复计划。其中一些原因如下:
- 用户错误 - 通常,用户错误是数据库数据破坏或损坏的最大原因。要纠正错误,需要将数据库恢复到错误发生之前的时间点。
- 硬件故障 - 这也可能导致数据库中的数据丢失。数据库存储在不同位置的多个硬盘上。这些硬盘有时可能会发生故障,导致数据库损坏。因此,定期更换它们很重要。
- 灾难性事件 - 灾难性事件可能是洪水或地震等自然灾害,也可能是黑客入侵数据库等蓄意破坏。无论哪种方式,数据库数据都可能被损坏,可能需要备份。
备份方法
数据库中备份的不同方法包括:
- 完整备份 - 此方法需要花费大量时间,因为需要制作数据库的完整副本,包括数据和交易记录。
- 交易日志 - 在此方法中,只有交易日志会保存为备份。为了使备份文件尽可能小,一旦制作了新的备份记录,就会删除以前的交易日志详细信息。
- 差异备份 - 这与完整备份类似,因为它同时存储数据和交易记录。但是,只有自上次完整备份以来发生变化的信息才会保存在备份中。因此,差异备份可使文件变小。
数据库恢复
有两种方法主要用于数据库恢复。它们是:
- 基于日志的恢复 - 在基于日志的恢复中,所有数据库事务的日志都存储在安全区域中,以便在系统发生故障时,数据库可以恢复数据。所有日志信息(例如事务时间、事务数据等)都应在执行事务之前存储。
- 影子分页 - 在影子分页中,事务完成后,其数据将自动存储以妥善保管。因此,如果系统在事务中间崩溃,则其所做的更改将不会反映在数据库中。