db2有表空间的LRG跟FLG文件,能恢复出来吗?

db2有表空间的LRG跟FLG文件,能恢复出来吗?,第1张

在弄明白什么是重定向恢复之前,需要知道数据库的文件构成,如果您对这一块比较熟悉,可以直接跳到第一条分割线:

首先,一个DB2数据库的文件是由两分部构成的:表空间容器和数据库文件,容器就是真正存放用户数据的地方,是创建表空间时定义的;数据库文件则包括了缓冲池信息文件、数据库配置文件、历史文件、日志控制文件等。

问题是,如何定义表空间容器以及数据库文件所在的路径呢?答:是create database以及create tablespace的时候的参数决定的:

1. 如果CREATE DATABASE的时候指定了 AUTOMATIC STORAGE NO:

没有指定ON path,那么数据库文件会被创建在数据库管理器配置文件dftdbpath指定的目录里;

若指定了ON path,那么数据库文件会被创建在ON指定的path里。

2. 如果CREATE DATABASE的时候指定了 AUTOMATIC STORAGE YES或者根本没有指定AUTOMATIC STORAGE:

2.1 没有指定ON path, 那么数据库文件和IBMSTOGROUP都会被创建/指定在dftdbpath指定的目录里

2.2 若指定了ON path, 这个path可以指定多个路径。 IBMSTOGROUP就使用这些路径,表空间容器路径解决了,数据库文件在哪里呢?这取决于DBPATH ON 参数:

没有指定DBPATH ON,数据库文件会被放在ON path指定的第一个路径里。

若指定了DBPATH ON, 数据库文件会放在这个路径下。

下面正式进入重定向复原,首先是什么情况下需要重定向恢复?

在下列任何情况下,请使用重定向复原 *** 作:

--如果要将备份映像复原到不同于源机器的目标机器

--如果要将表空间容器复原到另一个物理位置

--如果复原 *** 作由于一个或多个容器不可访问而失败

--如果要重新定义已定义的存储器组的路径

这儿我举一个例子,尽可能地将上面几种情况都包括了,假设我们有如下创建数据库以及表空间的命令:

dbm cfg: Default database path (DFTDBPATH) = /home/db2users/e105q6a

$ db2 "create db test"

$ db2 "connect to test"

$ db2 "create STOGROUP MQSGROUP ON '/home/db2users/e105q6a/conpath1', '/home/db2users/e105q6a/conpath2'"

$ db2 "create user temporary tablespace usrtmp1 managed by automatic storage"

$ db2 "create regular tablespace rglrtbs1 managed by automatic storage USING STOGROUP MQSGROUP"

$ db2 "create tablespace tbs1 managed by system using ('/home/db2users/e105q6a/path1')"

$ db2 "create tablespace tbs2 managed by database using (file 'con2' 4000)"

那么数据库文件、storage group以及各个表空间的容器路径如下:

数据库文件/数据库目录:

/home/db2users/e105q6a

Storage Group:

$ db2 "SELECT VARCHAR(STORAGE_GROUP_NAME, 15) AS STOGROUP, STORAGE_GROUP_ID, VARCHAR(DB_STORAGE_PATH, 40) AS STORAGE_PATH FROM TABLE(ADMIN_GET_STORAGE_PATHS('',-1)) AS T"

STOGROUP STORAGE_GROUP_ID STORAGE_PATH

---------------- ---------------- ----------------------------------------

IBMSTOGROUP 0 /home/db2users/e105q6a

MQSGROUP1 /home/db2users/e105q6a/conpath1

MQSGROUP1 /home/db2users/e105q6a/conpath2

3 record(s) selected.

表空间容器(我精简了输出):

$ db2pd -db test -tab

Database Member 0 -- Database TEST -- Active -- Up 0 days 00:16:02 -- Date 2017-02-25-10.28.54.331489

Tablespace Configuration:

Id AS AR Type Content SGID Name Type Container

0Yes Yes DMS Regular 0 SYSCATSPACE File /home/db2users/e105q6a/e105q6a/NODE0000/TEST/T0000000/C0000000.CAT

1Yes No SMS SysTmp 0 TEMPSPACE1Path /home/db2users/e105q6a/e105q6a/NODE0000/TEST/T0000001/C0000000.TMP

2Yes Yes DMS Large0 USERSPACE1File /home/db2users/e105q6a/e105q6a/NODE0000/TEST/T0000002/C0000000.LRG

3Yes Yes DMS Large0 SYSTOOLSPACE File /home/db2users/e105q6a/e105q6a/NODE0000/TEST/T0000003/C0000000.LRG

4Yes No SMS UsrTmp 0 USRTMP1 Path /home/db2users/e105q6a/e105q6a/NODE0000/TEST/T0000004/C0000000.UTM

5Yes Yes DMS Regular 1 RGLRTBS1 File /home/db2users/e105q6a/conpath1/e105q6a/NODE0000/TEST/T0000005/C0000000.USR

5Yes Yes DMS Regular 1 RGLRTBS1 File /home/db2users/e105q6a/conpath2/e105q6a/NODE0000/TEST/T0000005/C0000001.USR

6No No SMS Regular - TBS1 Path /home/db2users/e105q6a/path1

7No No DMS Large- TBS2 File /home/db2users/e105q6a/e105q6a/NODE0000/SQL00001/con2

----

以上面的数据库为例,假设想要通过重定向恢复达到以下目的:

1.)把数据库文件路径换为/home/db2users/e105q6a/targetdbdir

2.) 把IBMSTOGROUP的路径换为/home/db2users/e105q6a/targetstgrpsystem

3.)把MQSGROUP的路径换为/home/db2users/e105q6a/targetstgrpuser1, /home/db2users/e105q6a/targetstgrpuser2 和/home/db2users/e105q6a/targetstgrpuser3

4.)把表空间tbs1路径换为:/home/db2users/e105q6a/targetpath1

5.)把表空间tbs2路径换为:/home/db2users/e105q6a/targetcon2, 并将大小改为5000

要先通过"db2 drop db test"删掉数据库(模拟恢复到另一个机器上),之后针对上面这几个需求,相应的 *** 作如下:

1.)$ db2 "restore db test to '/home/db2users/e105q6a/targetdbdir' redirect without prompting"

2.)$ db2 "SET STOGROUP PATHS FOR IBMSTOGROUP ON '/home/db2users/e105q6a/targetstgrpsystem'"

3.)$ db2 "SET STOGROUP PATHS FOR MQSGROUP ON '/home/db2users/e105q6a/targetstgrpuser1', '/home/db2users/e105q6a/targetstgrpuser2', '/home/db2users/e105q6a/targetstgrpuser3' "

4.)$ db2 "set tablespace containers for 6 using (path '/home/db2users/e105q6a/targetpath1')"

5.)$ db2 "set tablespace containers for 7 using (file '/home/db2users/e105q6a/targetcon2' 5000)"

最后发出db2 restore db test continue的命令,完成重定向恢复。

DB2 提供了命令,供用户从一次数据库备份文件中提取数据库重定向恢复脚本。示例如下,其中 /db2_backup/db2inst1/sample 是数据库备份文件所在的目录,20101023180128 是数据库备份文件的时间戳。

db2 restore db sample from /db2_backup/db2inst1/sample taken at 20101023180128

redirect generate script redirect_sample.sql

DB20000I The RESTORE DATABASE command completed successfully.

备份文件中备份的是开始点数据库的一切数据,备份的时候数据变更会记载在日志里。通过恢复数据库和前滚日志的方式可以把数据恢复到备份后的状态。恢复的方法是:1》db2restoredb数据库名logtarget日志解压位置2》db2rollforwarddb数据库名toendoflogsandstopoverflowlogpath(“日志解压位置”)是需要把生产的归档日志都copy到测试环境中前滚,活动日志不需要copy


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

原文地址: http://outofmemory.cn/sjk/6657831.html

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

发表评论

登录后才能评论

评论列表(0条)

保存