您的位置: 首页 > 软件开发专栏 > 数据库 > 正文

数据库与其备份恢复主要注意事项

发表于:2022-03-01 作者:毕磊 来源: 存储灾备

1、数据库的模型

数据库的模型多达十几种,以下列出几种常见的数据库模型:

(1)关系型数据库,最为常见,是采用了关系模型来组织数据的数据库。关系模型指的就是二维表格模型,一个关系型数据库就是由二维表及其之间的联系所组成的一个数据组织;

(2)键值数据库是一种非关系数据库,它使用简单的键值方法来存储数据。键值数据库将数据存储为键值对集合,其中键作为唯一标识符。键和值都可以是从简单对象到复杂复合对象的任何内容。键值数据库是高度可分区的,并且允许以其他类的数据库无法实现的规模进行水平扩展;

(3)时间序列数据库,就是一个数据源会每隔一段时间产生一条数据,除了时间戳和值不一样,其他都相同。比如一个cpu的使用率,随着时间的变化不断变化,那么它产生的数据就是时间序列数据;

(4)文件型数据库应该和单机数据库是一个意思,是客户端对数据库的访问是通过直接访问数据库文件完成的,在传统的数据库中,信息被分割成离散的数据段,而在文档数据库中,文档是处理信息的基本单位。一文档可以很长、很复杂、可以无结构,与字处理文档类似。一个文档相当于关系数据库中的一条记录。

2、数据库术语

(1)数据文件,数据库存储其数据的位置,每个数据库大多具有多个文件,数据文件是在不断的更新的;

(2)桌子(Table),是在关系型数据库中,表示一堆相关值,类似于虚拟电子表格;

(3)表空间,是放置表Table的空间,是一个或多个数据文件的集合,如果数据库没有表,那么也就没有表空间;

(4)分区,现代数据库可以在多个资源(包括多个表空间)之间划分和分散表;

(5)分片,将分区扩展到另一个级别,是大规模扩展数据库的关键,甚至可以将表的碎片放到不同的节点上;

(6)主数据库,跟踪所有数据库和数据文件的状态,简称主库,就是集中存储管理历史归档数据的场所,它永久保管具有长期保留价值、有共享需求的、经过数据质量检查验证的,规范化的数据;

(7)事务,是数据库中的一项活动,可更改一个或者多个表中的一个或者多个属性;

(8)事务日志,记录每个事务以及更改哪些元素,或者说做了哪些操作。大部分类型的数据库都具有某种类型的日志,可以重播日志,然后在某个时间点还原事务,或者在崩溃后进行回滚。典型的还原是从最近的备份中还原数据库文件,然后从日志恢复。

3、数据库的数据一致模型

(1)即时一致性,也称为强一致性,它可以确保所有用户在同一时间看到相同的数据,无论他们在何处或以何种方式查看数据,大多数的关系型数据库都是遵循此模型;

(2)最终一致或者是弱一致的数据库,这可以确保给定的属性对于所有查看者都是一致的,但这可能需要一些时间,有一定的延迟。

4、针对数据库备份恢复要考虑的主要注意事项

(1)掌握以下几种备份类型:

物理备份:对数据库系统的物理文件(如数据文件,日志文件等)的备份,也可说是文件系统级别的备份,其中包含的方法:

冷备份(脱机备份):是在关闭数据库的时候进行的;

热备份(联机备份):数据库处于运行状态,依赖于数据库的日志文件;

温备份:数据库锁定表格(不可写入但可读)的状态下进行备份操作。

除了物理备份以外,还有一种叫逻辑备份:就是对数据库逻辑组件(如:表等数据库对象)的备份,备份文件是SQL文件或特定格式的导出文件。实际操作中大部分以物理备份为主,逻辑备份为辅。逻辑备份和物理备份各有优劣,一般来说,物理备份恢复速度比较快,但占用空间比较大,逻辑备份速度比较慢,占用空间比较小,但逻辑备份的恢复成本相对高一些;

(2)如何对数据和日志进行一致的备份,没有日志备份,就只能将数据库恢复到最后一次备份的结尾。如果发生灾难,数据库最后一次备份之后的数据修改将全部丢失,创建了第一个完整数据备份之后,便可以开始执行事务日志备份,事务日志备份计划,根据需要频率可多一些,而数据库数据的备份以适合数据库业务要求的间隔进行;

(3)要充分了解数据库的分布情况,是否已分区,是在一个主机中,还是分散在多个主机中;

(4)多个节点之间的使用了复制功能的数据库,仍然需要常规传统备份,因为如果是人为错误删除表,只有复制的话将无法还原;

(5)如何进行可靠的还原和验证,备份只是第一步,可用、可靠,完整的恢复才是最重中之重;

(6)数据库备份期间一般不能进行实例重启和升级的操作,很有可能会损坏数据。