全部博文(74)
分类: 服务器与存储
2008-05-04 18:13:06
本文讲述了克隆 DB2 for Linux、UNIX 或 Windows 数据库的基础知识。
本文适用于 IBM® DB2® Universal Database™ for Linux、UNIX® 和 Windows®
数据库恢复操作使用数据库备份映象来重新创建数据库。如果要将数据库从一台机器克隆到另一台,最简单的方法就是从备份映象恢复数据库。数据库使用的文件系统路径也包含在备份映象中。因此,除非源系统上的数据库引用的文件系统和物理设备与目标系统的设置方法完全相同,否则就需要执行 重定向恢复操作。
提示:如果有 DB2 V8,就可以从任何高位优先服务器获取备份,并将它恢复到任何其它高位优先服务器。例如,您可以将备份映象从 DB2 for HP-UX 恢复到 DB2 for AIX® 或 Sun Solaris。但是,这并不适用于 Windows 和 Linux。
重定向恢复操作包括两步数据库恢复过程,并且中间有一个表空间容器定义步骤:
整个重定向恢复操作必须在同一个会话中调用;否则,将返回 SQL0900N,恢复操作会失败,记住这一点很重要。确保不会发生这种情况的一个方法是创建并运行包含重定向恢复过程中全部三部分的脚本。
以下(Windows)示例显示了如何成功地执行重定向恢复操作。我将演示如何从不同的 实例恢复备份映象,而不是从另一台 服务器恢复备份映象。原理相同,细节也一样。
本示例中的源实例名为 PROD。目标实例名为 MYINST。将要在 MYINST 上被恢复(创建)的 PROD 上的现有数据库名为 MOVIES。MOVIES 数据库在 D 盘上。
set DB2INSTANCE=PROD db2start db2 backup db movies |
这个映象的时间戳记是 20021006213640
,该映象在 D:\MOVIES.0\PROD\NODE0000\CATN0000\20021006
中。DB2 在发出 BACKUP DATABASE 命令的目录中创建这个子目录树。子目录名称表示以下含义:
|
在这个子目录树中,将会有一个表示实际备份映象的文件(213640.0)。文件名表示获取备份的时间。
md MOVIES.0\MYINST\NODE0000\CATN0000\20021006 |
这是关键步骤:如果没有正确创建这个路径,后续的数据库恢复操作就会失败。如果正在将备份映象重新定位到另一台机器,那么在目标机器上创建上述路径(用适当的目标实例名代替 MYINST),并且将备份映象(在此案例中是 213640.0)复制到该目录。在为传送维护目录树时,也可以使用压缩工具将备份映象打包。
set DB2INSTANCE=MYINST db2start db2 restore db movies from d taken at 20021006213640 to d redirect |
如果从不包含备份映象的目录中调用 DATABASE RESTORE 命令,则必须指定 FROM 参数。TO 参数指定了目标数据库目录(只有在 Windows 操作系统上要指定盘符)。
db2 set tablespace containers for 0 using (path 'd:\ts0con1') db2 set tablespace containers for 1 using (path 'd:\ts1con1') db2 set tablespace containers for 2 using (path 'd:\ts2con1') |
可以使用 LIST TABLESPACES SHOW DETAIL 命令来获取关于源数据库中所有表空间的信息;这将帮助您确保已经为目标数据库中的所有表空间设置了容器。
db2 restore db movies continue |
db2 list db directory db2 connect to movies db2 list tablespace containers for 0 db2 list tablespace containers for 1 db2 list tablespace containers for 2 db2 connect reset db2 terminate db2stop set DB2INSTANCE=PROD db2stop |
有关 DB2 备份和恢复操作的更多信息,请参阅 David Kline 的文章 生产到开发:转移数据库。