如何让DB2数据库数据备份与恢复的效率更高

如何让DB2数据库数据备份与恢复的效率更高,第1张

亡羊补牢这一成语在数据领域同样适用,但是亡羊之后不仅要补牢,还要恢复原来的羊。在DB2数据库中,数据的备份和恢复同样重要。在日常的工作中,DB2数据库数据备份与恢复的频率很高,但是如果效率很低,会占用很多时间,并且对使用者的数据恢复和使用产生很差的影响。那么,便成为很多数据库管理员需要深入研究的问题。 一、了解数据的逻辑存储结构。 如果以前有Oracle数据库经验的管理员,那么了解DB2数据库的逻辑存储结构就比较容易了,因为两者在这方面很类似。对于DB2数据库来说,其逻辑存储结构主要分为数据表、表空间与数据库三个级别。数据表包含在表空间之中,而表空间又包含在数据库当中。换一句话说,一个DB2数据库包含多个表空间,而每个表空间又包含了多个数据表。一个数据表示不能够保存在多个表空间当中的。同理,一个表空间也不能够保存在多个数据库之中。这跟小学的实施,班级里分组类似。一个班(相当于一个数据库)分为四个小组(每个小组相当于一个表空间),然后每个小组又是由一个个的学生组成的(一个个学生相当于一个个数据表)。这个组织结构可以有什么好处呢此时学校校长(相当于数据库管理员)就可以按照班级、小组为单位对数据进行管理,也可以对学生进行一对一的面谈,从而提高数据库管理的灵活性。 而对于数据备份与恢复作业来说,采用如此的逻辑结构,数据库管理员既可以对整个数据库进行备份与恢复(对整个班级进行管理);也可以以表空间为单位,对表空间中的所有数据表进行备份与恢复 *** 作(以小组为单位进行管理);甚至可以对单独的数据表进行备份与恢复的 *** 作(对单个学生进行管理)。即可以分别从数据表、表空间、数据库三个级别来进行备份与恢复的 *** 作。这分级别的管理,不仅增强了 *** 作的灵活性,而且还可以提高备份与 *** 作的效率。如现在用户需要对某个表进行更新,如需要调整价格表中的价格。此时数据库管理员就只需要对价格表进行更新即可,而不需要对整个数据库进行备份。显然这可以减少备份的时间。若出现问题的话,也只需要对这张表中的内容进行恢复。这也可以在很大程度上减少恢复的时间。恢复一张表肯定比恢复整个数据库所用的时间要少的多。 二、合理规划表空间提高数据库备份恢复性能。 既然数据库备份与恢复可以按三个级别来进行,那么数据库管理员可以根据这个特性来合理规划表空间,以提高数据库备份与恢复的性能。如在DB2数据库中,虽然对于LOB等大容量数据类型提供了很好的支持。但是,毕竟其容量比较大,有时候其所占的数据库容量可能达到整个数据库的二分之一。为此这些大容量的数据类型就成为了数据库备份与恢复作业作业的性能瓶颈。如果在数据库备份与恢复的时候,不备份这些LOB数据类型的数据,那么数据库备份与恢复的时间可能会减少三分之一,甚至二分之一。 为此笔者建议,在规划数据表的时候,最好将LOB数据类型的数据与其他数据分成两张表来存放。如在一个产品信息表的表中,包含一个产品的字段,这个字段就是一个LOB数据类型。虽然可以将它们设计在同一个表中。不过笔者还是建议将他们分为两个表来存放,然后通过关键字将他们连接起来。最后将这个两张表分别存放到不同的表空间中。如将有LOB数据类型的表统一保存在LOB表空间中。如此有什么好处呢当数据库进行备份时,平时可以只对非LOB表空间中的数据进行备份。由于LOB表空间中的一些信息一般不怎么会更新,就可以一个星期更新一次。或者让其在数据库比较空闲的时间进行备份。经过一段时间的测试,可以发现每天或者每周数据库的空闲时断。如此规划的话,就可以将平时备份的效率提高。同理,在恢复的时候也可以按照表空间级别来进行恢复,从而缩短数据库恢复的时间。 这个方案的核心就是将LOB等大容量数据类型的数据与普通表独立开来,并且存放在不同的表空间中。然后将LOB表空间与非LOB表空间进行分开管理,分开备份与恢复,从而提高数据库备份与恢复的效率。为此在建立表时将LOB数据类型与其他数据类型分开存放是关键。 三、对于等LOB数据类型的另类处理方式。 当数据库中LOB数据类型比较多的时候,往往会在很大程度上影响数据库的性能。不仅数据备份与恢复会受到影响,连平时的查询也会受到牵连。为此笔者有时候给企业部署DB2数据库系统的时候,往往会建议他们,不要将等信息存放在数据库中。那么当用户需要查询信息时,该如何处理呢笔者建议他们将统一放到网络上的一个共享服务器中。然后在数据库中只存放这个的路径。最后在客户端界面设计时,可以创建一个指向的链接。当用户需要访问某个产品的信息时,则只需要点击产品管理界面上的链接,就可以打开这张。在这种情况下,数据库实际存储的只是的路径(也就是一个普通的字符型字段),而不是本身。故可以提高客户端窗口显示的速度,同时也可以提高数据库备份与恢复的效率。 四、为系统设置合适的并行度与缓存来提高数据库备份与恢复性能。 数据库备份与恢复的性能除了跟数据类型有关之外,还跟系统的并行度与缓冲区有关。通常情况下,如果硬件设备支持的话,增加并行度与增加缓冲区的大小可以提高数据库备份与恢复的性能。为此在对DB2数据库进行备份的时候,可以通过给并行度、缓冲区树木和缓冲区大小分配合适的值来提高数据库备份与恢复的性能。如一般情况下,笔者建议将数据库缓冲区的大小设置为数据内存的二倍到三倍。如果备份中包含大容量的数据类型,可以适当提高整个比例。并且将数据库缓冲区的数目设置为硬盘I/O缓冲数目的两倍。如此设置之后,数据库的备份与恢复性能能够得到很大的改善。 不过需要注意的是,这个调整会受到服务器硬件资源的限制。当服务器内存等硬件设备不支持这么大的数据缓冲区与数据缓冲区数目时,反而会因为没有足够的内存分配给缓冲区,从而导致数据备份与恢复的失败。为此笔者建议,在调整数据缓冲区的时候,需要特别注意。一般来说,调整好这些参数之后,需要持续追踪一段时间,以确保这些调整不会影响到数据库的正常备份与恢复,不会与数据库的硬件配置相冲突。

你需要先

db2look

-db

testdb

-o

looksql把创建数据库用的sql语句拿出来,在你本地按照前面的looksql建好数据库,然后用load或者import把你export出来的数据倒进数据库里去就可以了。

其实你可以先db2look,再用db2move命令把数据倒出来,建立数据库,再用db2move把数据倒进去。

SQL1224N 由于数据库管理器发生了错误或者被强制中断,从而无法接

受新的请求,已终止正在处理的所有请求或者已终止所指定的请求。

说明:

此消息可能是由于下列任何一种原因所致。

1

尚未在数据库服务器上启动数据库管理器。

数据库管理器已停止。

系统管理员已强行终止数据库代理程序。

数据库代理程序已由于关键数据库管理器进程异常终止而终止。

重启一下数据库实例试试

脚本内容如下:

/home/db2inst1/sqllib/db2profile

db2 connect to DB user USERNAME using PASSWORD

db2 import from xdel of delmessages logmsg insert into xxx

db2ckbkp命令不仅可以用来检查DB2数据库备份文件的完整性,而且还可以用来查询DB2数据库备份文件的元数据,如果我们有一些备份文件,但是不知道备份的类型,我们可以使用db2ckbkp -H <备份文件>来检查DB2数据库备份的类型:

#db2ckbkp -H WWQ0gmcwNODE0000CATN000020130107000019001

我们可以通过上述输出中的Backup Mode, Backup Type 和Backup Gran来确定备份的类型,三个关键字的说明如下:

Backup Mode 0 - offline(脱机备份), 1 - online(联机备份)

Backup Type 0 - full(全备份), 3 - tablespace(表空间级备份)

Backup Gran 0 - normal(正常备份), 16 - incremental(增量备份), 48 - delta(增量delta备份)

其中incremental(增量备份)和delta(增量delta备份)的说明如下:

Incremental(增量备份): 增量备份映像是自从上次最新的、成功的完全备份 *** 作以来,更改过的所有数据库数据的副本。也称为累积备份映像,因为进行的一系列增量备份中的每一个都会有上次增量备份映像的内容。增量备份映像的前身通常是同一对象最新的、成功的完全备份。

Delta(增量delta备份): delta 备份映像或增量 delta 备份映像是自从上次相关表空间的成功备份(包括完整、增量或 delta 备份)以来,已更改过的所有数据库数据的副本。也称为差异备份映像或非累积备份映像。delta 备份映像的前身是最新的成功备份,包括 delta 备份映像中每个表空间的备份。

明确了上述数字的含义后,我们就可以很容易地辨别上述备份文件是属于“联机全备份”:

Backup Mode -- 1 (联机备份)

Backup Type -- 0 (全备份)

Backup Gran -- 0 (正常备份)

我做过相反的过程,一点问题都没有。

所以将windows下的数据库备份文件直接复制到LINUX下,在LINUX下创建一个同名空库,然后执行restore db命令,应该成功的。

另外一种方法是可以用db2look取得windows数据库的DDL语句,到LINUX系统下执行一遍。数据依靠windows下执行EXPORT命令导出,LINUX下IMPORT。

你需要先 db2look -db testdb -o looksql把创建数据库用的sql语句拿出来,在你本地按照前面的looksql建好数据库,然后用load或者import把你export出来的数据倒进数据库里去就可以了。 其实你可以先db2look,再用db2move命令把数据倒出来,建立数据库,再用db2move把数据倒进去。

db2的备份分为脱机备份(冷备)和联机备份(热备)

脱机备份

语法:backup database DB to D:\

联机备份

对于联机备份,有两种可以采用的备份级别:表空间级和数据库级联机备份。并且有两种执行联机备份的方法。可以使用 Control Center GUI 或 CLP 命令行提示来执行联机备份。

以上就是关于如何让DB2数据库数据备份与恢复的效率更高全部的内容,包括:如何让DB2数据库数据备份与恢复的效率更高、怎么用db2把远程服务器上备份下来整个库导入本地新建的db2数据库中、DB2备份报错如何处理等相关内容解答,如果想了解更多相关内容,可以关注我们,你们的支持是我们更新的动力!

欢迎分享,转载请注明来源:内存溢出

原文地址: https://outofmemory.cn/sjk/9465579.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-04-28
下一篇 2023-04-28

发表评论

登录后才能评论

评论列表(0条)

保存