如果备份或者恢复一个DB2数据库备份与恢复需要花费几个小时时间,那么及时这个备份与恢复
方案再安全,也于事无补。或者说,是一个不合适的解决方案。为此在考虑备份恢复方案本身安全性的同时,也需要兼顾备份与恢复的效率。在这篇文章中,笔者就介绍一下提高数据备份与恢复效率的一些常用技巧。经过笔者多个案例的实际应用,证明这些技巧在提高DB2数据库备份与恢复的性能具有很大的帮助。
一、了解数据的逻辑存储结构。如果以前有Oracle数据库经验的管理员,那么了解DB2数据库备份与恢复的逻辑存储结构就比较容易了,因为两者在这方面很类似。对于DB2数据库备份与恢复来说,其逻辑存储结构主要分为数据表、表空间与数据库三个级别。数据表包含在表空间之中,而表空间又包含在数据库当中。换一句话说,一个DB2数据库包含多个表空间,而每个表空间又包含了多个数据表。一个数据表示不能够保存在多个表空间当中的。同理,一个表空间也不能够保存在多个数据库之中。这跟小学的实施,班级里分组类似。一个班(相当于一个数据库)分为四个小组(每个小组相当于一个表空间),然后每个小组又是由一个个的学生组成的(一个个学生相当于一个个数据表)。这个组织结构可以有什么好处呢?此时学校校长(相当于数据库管理员)就可以按照班级、小组为单位对数据进行管理,也可以对学生进行一对一的面谈,从而提高数据库管理的灵活性。
而对于数据备份与恢复作业来说,采用如此的逻辑结构,数据库管理员既可以对整个数据库进行备份与恢复(对整个班级进行管理);也可以以表空间为单位,对表空间中的所有数据表进行备份与恢复操作(以小组为单位进行管理);甚至可以对单独的数据表进行备份与恢复的操作(对单个学生进行管理)。即可以分别从数据表、表空间、数据库三个级别来进行备份与恢复的操作。这分级别的管理,不仅增强了操作的灵活性,而且还可以提高备份与操作的效率。如现在用户需要对某个表进行更新,如需要调整价格表中的价格。此时数据管理员就只需要对价格表进行更新即可,而不需要对整个数据库进行备份。显然这可以减少备份的时间。若出现问题的话,也只需要对这张表中的内容进行恢复。这也可以在很大程度上减少恢复的时间。恢复一张表肯定比恢复整个数据库所用的时间要少的多。
二、合理规划表空间提高数据库备份恢复性能。既然数据库备份与恢复可以按三个级别来进行,那么数据库管理员可以根据这个特性来合理规划表空间,以提高数据库备份与恢复的性能。如在DB2数据库备份与恢复中,虽然对于LOB等大容量数据类型提供了很好的支持。但是,毕竟其容量比较大,有时候其所占的数据库容量可能达到整个数据库的二分之一。为此这些大容量的数据类型就成为了数据库备份与恢复作业作业的性能瓶颈。如果在数据库备份与恢复的时候,不备份这些LOB数据类型的数据,那么数据库备份与恢复的时间可能会减少三分之一,甚至二分之一。
为此笔者建议,在规划数据表的时候,最好将LOB数据类型的数据与其他数据分成两张表来存放。如在一个产品信息表的表中,包含一个产品图片的字段,这个字段就是一个LOB数据类型。虽然可以将它们设计在同一个表中。不过笔者还是建议将他们分为两个表来存放,然后通过关键字将他们连接起来。最后将这个两张表分别存放到不同的表空间中。如将有LOB数据类型的表统一保存在LOB表空间中。如此有什么好处呢?当数据库进行备份时,平时可以只对非LOB表空间中的数据进行备份。由于LOB表空间中的一些信息一般不怎么会更新,就可以一个星期更新一次。或者让其在数据库比较空闲的时间进行备份。经过一段时间的测试,可以发现每天或者每周数据库的空闲时断。如此规划的话,就可以将平时备份的效率提高。同理,在恢复的时候也可以按照表空间级别来进行恢复,从而缩短DB2数据库备份与恢复的时间。
这个方案的核心就是将LOB等大容量数据类型的数据与普通表独立开来,并且存放在不同的表空间中。然后将LOB表空间与非LOB表空间进行分开管理,分开备份与恢复,从而提高数据库备份与恢复的效率。为此在建立表时将LOB数据类型与其他数据类型分开存放是关键。