热门标签 | HotTags
当前位置:  开发笔记 > 数据库 > 正文

DB2数据库利用备份实现异机还原实例分析

一生产的DB2数据库需要将其数据全部备份,然后还原导入到一测试库中,中间遇到一些问题,最后还是圆满解决了,现将步骤记录下来方便学习和分析。系统环境:AIX5.

一生产的DB2数据库需要将其数据全部备份,然后还原导入到一测试库中,中间遇到一些问题,最后还是圆满解决了,现将步骤记录下来方便学习和分析。系统环境:AIX5.

一生产的DB2数据库需要将其数据全部备份,香港虚拟主机,然后还原导入到一测试库中,中间遇到一些问题,最后还是圆满解决了,香港服务器,现将步骤记录下来方便学习和分析。

系统环境:AIX5.3

数据库: DB2 V9.1

两台服务器: 生产服务器 192.168.11.178

测试服务器 10.10.11.81

一、备份

分别备份一下生产服务器和测试服务器的数据库(两个服务器上数据库一样)

$ db2 backup db LAW online to /basefsnew/db2bak0111 include logs #生产

备份成功。此备份映像的时间戳记是:20130111180236

$ db2 backup db LAW online to /basefs/db2bak0111 include logs #测试

备份成功。此备份映像的时间戳记是:20130111190381

二、将生产库的备份传送到测试服务器

大家可以利用SCP命令或其他文件传输软件来传送备份,香港服务器,这里提醒一下传过来的备份需要改属主和属组还有权限,否则将导致还原时出错

三、具体还原过程和问题解决

$ db2 force applications all (先停止所有应用连接)
DB20000I The FORCE APPLICATION command completed successfully.
DB21024I This command is asynchronous and may not be effective immediately.

在测试服务器上开始还原
$ db2 restore db LAW from /home taken at 20130111180236
SQL2539W Warning! Restoring to an existing database that is the same as the backup image database. The database files will be deleted.
Do you want to continue ? (y/n) y
DB20000I The RESTORE DATABASE command completed successfully.
还原成功

但随后连接数据库时报错

$ db2 connect to LAW
SQL1117N A connection to or activation of database "LAW" cannot be made
because of ROLL-FORWARD PENDING. SQLSTATE=57019

这个提示是说需要前滚期间的日志才能激活数据库

下面执行此句进行前滚

$ db2 rollforward db LAW to end of logs and complete
SQL4970N Roll-forward recovery on database "LAW" cannot reach the specified
stop point (end-of-log or point-in-time) because of missing log file(s) on
node(s) "0".

提示缺失日志,不能到达结束点

注:比较顺利一次成功时,是这个状态

$db2 rollforward db LAW to end of logs and complete

Rollforward Status

Input database alias = db
Number of nodes have returned status = 1

Node number = 0
Rollforward status = not pending
Next log file to be read =
Log files processed = -
Last committed transaction = 2013-1-11-10.59.23.000000

DB20000I The ROLLFORWARD command completed successfully.

下面通过这个命令看一下数据库的状态和提示
$ db2 rollforward db LAW query status

Rollforward Status

Input database alias = LAW
Number of nodes have returned status = 1

Node number = 0
Rollforward status = DB working
Next log file to be read = S0003169.LOG
Log files processed = -
Last committed transaction = 2012-08-24-12.02.32.000000
通过这个命令,我们发现提示下一个日志为S0003169.LOG,
需要找到这个文件所在的路径,将生产服务器上从备份时间点后的日志全部同步或拷贝到测试服务器。
找到生产服务器上DB2日志,目录为/home/db2logs/db2inst2/LAW/NODE0000/C0000004
将此目录下从做备份的那个时间点后的日志全部拷贝放到测试服务器的相应目录(可以放到库备份的那个目录)下,同时注意修改日志文件的属主、属组和权限,防止权限不一致问题。

# chown db2inst1:db2iadm1 S0003170.LOG
# chown db2inst1:db2iadm1 S0003171.LOG
# chown db2inst1:db2iadm1 S0003172.LOG
# chown db2inst1:db2iadm1 S0003173.LOG
# chown db2inst1:db2iadm1 S0003174.LOG
# chown db2inst1:db2iadm1 S0003175.LOG
# chown db2inst1:db2iadm1 S0003176.LOG
#chmod 744 S0003170.LOG
#chmod 744 S0003171.LOG
#chmod 744 S0003172.LOG
#chmod 744 S0003173.LOG
#chmod 744 S0003174.LOG
#chmod 744 S0003175.LOG
#chmod 744 S0003176.LOG

用如下命令来前滚日志并停止日志的溢出,注意"("/home")"格式,指的是日志所在的路径

$ db2 rollforward db LAW to end of logs and stop overflow log path "("/home")"

推荐阅读
  • 1:有如下一段程序:packagea.b.c;publicclassTest{privatestaticinti0;publicintgetNext(){return ... [详细]
  • 深入理解 SQL 视图、存储过程与事务
    本文详细介绍了SQL中的视图、存储过程和事务的概念及应用。视图为用户提供了一种灵活的数据查询方式,存储过程则封装了复杂的SQL逻辑,而事务确保了数据库操作的完整性和一致性。 ... [详细]
  • 本周信息安全小组主要进行了CTF竞赛相关技能的学习,包括HTML和CSS的基础知识、逆向工程的初步探索以及整数溢出漏洞的学习。此外,还掌握了Linux命令行操作及互联网工作原理的基本概念。 ... [详细]
  • 构建基于BERT的中文NL2SQL模型:一个简明的基准
    本文探讨了将自然语言转换为SQL语句(NL2SQL)的任务,这是人工智能领域中一项非常实用的研究方向。文章介绍了笔者在公司举办的首届中文NL2SQL挑战赛中的实践,该比赛提供了金融和通用领域的表格数据,并标注了对应的自然语言与SQL语句对,旨在训练准确的NL2SQL模型。 ... [详细]
  • 本文详细介绍了HTML中标签的使用方法和作用。通过具体示例,解释了如何利用标签为网页中的缩写和简称提供完整解释,并探讨了其在提高可读性和搜索引擎优化方面的优势。 ... [详细]
  • 数据库内核开发入门 | 搭建研发环境的初步指南
    本课程将带你从零开始,逐步掌握数据库内核开发的基础知识和实践技能,重点介绍如何搭建OceanBase的开发环境。 ... [详细]
  • 本文深入探讨 MyBatis 中动态 SQL 的使用方法,包括 if/where、trim 自定义字符串截取规则、choose 分支选择、封装查询和修改条件的 where/set 标签、批量处理的 foreach 标签以及内置参数和 bind 的用法。 ... [详细]
  • 使用C#开发SQL Server存储过程的指南
    本文介绍如何利用C#在SQL Server中创建存储过程,涵盖背景、步骤和应用场景,旨在帮助开发者更好地理解和应用这一技术。 ... [详细]
  • 本文探讨了适用于Spring Boot应用程序的Web版SQL管理工具,这些工具不仅支持H2数据库,还能够处理MySQL和Oracle等主流数据库的表结构修改。 ... [详细]
  • 本文详细介绍了如何通过多种编程语言(如PHP、JSP)实现网站与MySQL数据库的连接,包括创建数据库、表的基本操作,以及数据的读取和写入方法。 ... [详细]
  • 在当前众多持久层框架中,MyBatis(前身为iBatis)凭借其轻量级、易用性和对SQL的直接支持,成为许多开发者的首选。本文将详细探讨MyBatis的核心概念、设计理念及其优势。 ... [详细]
  • 在使用 DataGridView 时,如果在当前单元格中输入内容但光标未移开,点击保存按钮后,输入的内容可能无法保存。只有当光标离开单元格后,才能成功保存数据。本文将探讨如何通过调用 DataGridView 的内置方法解决此问题。 ... [详细]
  • 本文详细介绍了如何在 Linux 平台上安装和配置 PostgreSQL 数据库。通过访问官方资源并遵循特定的操作步骤,用户可以在不同发行版(如 Ubuntu 和 Red Hat)上顺利完成 PostgreSQL 的安装。 ... [详细]
  • 如何在PostgreSQL中查看数据表
    本文将指导您使用pgAdmin工具连接到PostgreSQL数据库,并展示如何浏览和查找其中的数据表。通过简单的步骤,您可以轻松访问所需的表结构和数据。 ... [详细]
  • 利用存储过程构建年度日历表的详细指南
    本文将介绍如何使用SQL存储过程创建一个完整的年度日历表。通过实例演示,帮助读者掌握存储过程的应用技巧,并提供详细的代码解析和执行步骤。 ... [详细]
author-avatar
手机用户2502902843
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有