打开APP
userphoto
未登录

开通VIP,畅享免费电子书等14项超值服

开通VIP
跨平台恢复数据库
DB2 基础: 使用重定向恢复克隆 DB2 数据库
Roman B. Melnyk, DB2 信息开发, IBM 多伦多实验室
简介: 本文讲述了克隆 DB2 for Linux、UNIX 或 Windows 数据库的基础知识。
发布日期: 2002 年 12 月 01 日
级别: 初级
访问情况 : 6139 次浏览
评论: 0 (查看 | 添加评论 - 登录)
 平均分 (10个评分)
为本文评分
本文适用于 IBM? DB2? Universal Database? for Linux、UNIX? 和 Windows?
数据库恢复操作使用数据库备份映象来重新创建数据库。如果要将数据库从一台机器克隆到另一台,最简单的方法就是从备份映象恢复数据库。数据库使用的文件系统路径也包含在备份映象中。因此,除非源系统上的数据库引用的文件系统和物理设备与目标系统的设置方法完全相同,否则就需要执行 重定向恢复操作。
提示:如果有 DB2 V8,就可以从任何高位优先服务器获取备份,并将它恢复到任何其它高位优先服务器。例如,您可以将备份映象从 DB2 for HP-UX 恢复到 DB2 for AIX? 或 Sun Solaris。但是,这并不适用于 Windows 和 Linux。重定向恢复操作包括两步数据库恢复过程,并且中间有一个表空间容器定义步骤:
带 REDIRECT 选项发出 RESTORE DATABASE 命令。
使用 SET TABLESPACE CONTAINERS 命令来定义被恢复的数据库的表空间容器(DB2 需要知道您想要让表空间驻留在目标系统上的什么位置)。
再次发出 RESTORE DATABASE 命令,这次指定 CONTINUE 选项。
整个重定向恢复操作必须在同一个会话中调用;否则,将返回 SQL0900N,恢复操作会失败,记住这一点很重要。确保不会发生这种情况的一个方法是创建并运行包含重定向恢复过程中全部三部分的脚本。
以下(Windows)示例显示了如何成功地执行重定向恢复操作。我将演示如何从不同的 实例恢复备份映象,而不是从另一台 服务器恢复备份映象。原理相同,细节也一样。
本示例中的源实例名为 PROD。目标实例名为 MYINST。将要在 MYINST 上被恢复(创建)的 PROD 上的现有数据库名为 MOVIES。MOVIES 数据库在 D 盘上。
创建 PROD 上的 MOVIES 数据库的完整数据库备份映象:set DB2INSTANCE=PRODdb2startdb2 backup db movies
这个映象的时间戳记是 20021006213640 ,该映象在 D:\MOVIES.0\PROD\NODE0000\CATN0000\20021006 中。DB2 在发出 BACKUP DATABASE 命令的目录中创建这个子目录树。子目录名称表示以下含义:
<database_alias.backup_type>\<instance_name>\<node_number>\<catalog_node_number>\<date>
在这个子目录树中,将会有一个表示实际备份映象的文件(213640.0)。文件名表示获取备份的时间。
创建相似的路径(使用 MYINST 代替 PROD):
md MOVIES.0\MYINST\NODE0000\CATN0000\20021006
这是关键步骤:如果没有正确创建这个路径,后续的数据库恢复操作就会失败。如果正在将备份映象重新定位到另一台机器,那么在目标机器上创建上述路径(用适当的目标实例名代替 MYINST),并且将备份映象(在此案例中是 213640.0)复制到该目录。在为传送维护目录树时,也可以使用压缩工具将备份映象打包。
启动 MYINST,然后调用重定向恢复操作的第一步。
set DB2INSTANCE=MYINSTdb2startdb2 restore db movies from d taken at 20021006213640 to d redirect
如果从不包含备份映象的目录中调用 DATABASE RESTORE 命令,则必须指定 FROM 参数。TO 参数指定了目标数据库目录(只有在 Windows 操作系统上要指定盘符)。
为与所恢复的数据库相关的三个缺省表空间(SYSCATSPACE、TEMPSPACE1 和 USERSPACE1)定义新的表空间容器:
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 directorydb2 connect to moviesdb2 list tablespace containers for 0db2 list tablespace containers for 1db2 list tablespace containers for 2db2 connect resetdb2 terminatedb2stopset DB2INSTANCE=PRODdb2stop
有关 DB2 备份和恢复操作的更多信息,请参阅 David Kline 的文章 生产到开发:转移数据库
本站仅提供存储服务,所有内容均由用户发布,如发现有害或侵权内容,请点击举报
打开APP,阅读全文并永久保存 查看更多类似文章
猜你喜欢
类似文章
【热】打开小程序,算一算2024你的财运
如何综合掌握 DB2 和 Informix - Unix爱好者家园
Oracle知识点总结二
DB2 常用命令小结
修复SQLSERVER2000数据库之实战经验
有关DB2的FAQ!
WebSphere认证系列>>无忧题库网
更多类似文章 >>
生活服务
热点新闻
分享 收藏 导长图 关注 下载文章
绑定账号成功
后续可登录账号畅享VIP特权!
如果VIP功能使用有故障,
可点击这里联系客服!

联系客服