DB2数据库备份与恢复

1.    备份

1.1离线备份(必须在数据库所在PC机进行操作)

STEP 1 连接到要备份的数据库

C:\Documents and Settings\Administrator>db2 connect to ncc user nccwykpi using nccwykpi

STEP 2 显示数据库应用状态

C:\Documents and Settings\Administrator>db2 list applications

STEP 3 停掉数据库应用

C:\Documents and Settings\Administrator>db2 force applications all

注意:由于该命令是异步的,所以在进行备份的时候会出现以下错误信息。此时可以再次执行db2 force applications all 命令。

STEP 4 对数据库进行离线状态下的备份

C:\Documents and Settings\Administrator>db2 backup database ncc to d:\db2\backup

注意:指定的备份文件的输出目录必须是已创建的,否则会报错。

STEP 5 查看备份历史记录

C:\Documents and Settings\Administrator>db2 list history backup all for ncc

1.2在线备份

注意:如果要做在线的备份,要对两个参数作修改:USEREXIT和LOGRETAIN,将其修改为on,默认是off的,默认使用日志模式,修改完参数后,可以变为归档日志模式,启用了userexit做数据库日志的归档。

STEP 1 查看数据库当前的属性

C:\Documents and Settings\Administrator>db2 get db cfg

STEP 2 设置userexit、logretain参数的状态为on

C:\Documents and Settings\Administrator>db2 update db cfg for ncc using userexit on

C:\Documents and Settings\Administrator>db2 update db cfg for ncc using logretain on

注意:修改配置参数必须是数据库管理员,并且必须停掉全部应用后更改才会生效。

STEP 3 连接需要备份的数据库(注意)

注意:此时由于数据库处于backup pending状态,所以必须做一次离线的全备才可以进行数据库连接。

STEP 4 对数据库进行在线状态下的备份

C:\Documents and Settings\Administrator>db2 backup database ncc online to d:\db2\backup


1.3增量备份

注意:必须要修改trackmod为on状态,并有一次完全备份。

STEP 1 修改trackmod参数为on状态

C:\Documents
and Settings\Administrator>db2 update db cfg for ncc
using trackmod yes

STEP 2 停掉数据库应用

C:\Documents
and Settings\Administrator>db2 force applications
all

STEP 3 对数据库进行增量备份

C:\Documents
and Settings\Administrator>db2 backup database ncc online increment

al
delta to d:\db2\backup

 

注意:在进行增量备份之前需要做一次离线的全备。否则是backup pending状态的。 

如若此时并未执行一次离线的全备那么会出现下面的错误。

故:


2.   
恢复

2.1恢复完全备份

STEP 1 查看备份历史记录

C:\Documents
and Settings\Administrator>db2 list history backup
all for ncc

STEP 2 停掉数据库应用

C:\Documents
and Settings\Administrator>db2 force applications
all

STEP 3 恢复某个时间点的数据

C:\Documents
and Settings\Administrator>db2 restore database ncc
from d:\db2\backup taken at 20120206094204

STEP 4 回滚到日志结束(可不执行,即不恢复日志)

C:\Documents
and Settings\Administrator>db2 rollforward database
ncc to end of logs and stop


2.2恢复增量备份

STEP 1 连接数据库

C:\Documents
and Settings\Administrator>db2 connect to ncc user
nccwykpi using nccwykpi

STEP 2 显示数据库应用状态

C:\Documents
and Settings\Administrator>db2 list applications

STEP 3 停掉数据库应用

C:\Documents
and Settings\Administrator>db2 force applications
all

STEP 4 恢复增量备份

C:\Documents
and Settings\Administrator>db2 restore database ncc
incremental automatic from d:\db2\backup taken at 20120206133457

STEP 5 回滚到日志结束(可不执行,即不恢复日志)

C:\Documents
and Settings\Administrator>db2 rollforward database
ncc to end of logs and stop


3.   
检查备份完整性

当备份完成后,使用db2ckbkp命令不仅可以用来检查DB2数据库备份文件的完整性,而且还可以用来查询DB2数据库备份文件的元数据。同时可以使用db2ckbkp –h<备份文件>来检查DB2数据库备份的类型。

3.1使用db2ckbkp –h<备份文件>命令来查看DB2数据库备份的类型

C:\Documents
and Settings\Administrator>db2ckbkp -h
d:\db2\backup\NCC.0.DB2.NODE0000.CATN0000.20120206133232.001

注意:我们可以通过上述输出中的

来确定备份的类型。三个关键字的说明如下:

incremental和delta的说明如下:

3.2回滚日志

当回滚日志找不到日志文件而出错时,数据库处于roll-forward pending状态,此时不能连接或激活数据库。解决方案如下:

3.3数据库恢复

如果一个数据库启用了归档日志记录,那么当该数据库被恢复时,它将自动被置于rollforward
pending
状态。可以使用如下命令告诉DB2不要将该数据库置于rollforward
pending
状态。

 

C:\Documents
and Settings\Administrator>restore database ncc from
d:\db2\backup taken at 20120206151346 without
rolling forward

 

 

如果数据库启用了归档日志记录,处于rollforward
pending
状态,此时连接数据库将会提示

此时可使用如下命令使数据库状态恢复正常

此时再执行连接数据库即可连接成功。

Db2数据库的备份和恢复的更多相关文章

  1. 一、MySQL中的索引 二、MySQL中的函数 三、MySQL数据库的备份和恢复 四、数据库设计和优化(重点)

    一.MySQL中的索引###<1>索引的概念 索引就是一种数据结构(高效获取数据),在mysql中以文件的方式存在.存储建立了索引列的地址或者指向. 文件 :(以某种数据 结构存放) 存放 ...

  2. Python进阶----pymysql的安装与使用,mysql数据库的备份和恢复,mysql的事务和锁

    Python进阶----pymysql的安装与使用,mysql数据库的备份和恢复,mysql的事务和锁 一丶安装 pip install PyMySQL 二丶pymysql连接数据库 ### 语法: ...

  3. SQL数据库的备份和恢复

    SQL数据库的备份和恢复 一.SQL数据库的备份: 1.依次打开 开始菜单 → 程序 → Microsoft SQL Server 2008 → SQL Server Management Studi ...

  4. mysql数据库的备份和恢复

    Mysql数据库的备份和恢复 1.备份单个数据库 mysql数据库自带了一个很好用的备份命令,就是mysqldump,它的基本使用如下: 语法:mysqldump –u <用户名> -p ...

  5. db2数据库的备份与还原

    前言: 数据备份的重要性: 提高系统的高可用性和灾难可恢复性:(在数据库系统崩溃的时候,没有数据库备份怎么办!) 使用数据库备份还原数据库是数据库系统崩溃时提供数据恢复最小代价的最优方案:(总不能让客 ...

  6. postgresql 数据库的备份和恢复 (pg_dump 和 pg_restore)

    pg_dump 用来备份数据库: pg_restore 用来恢复数据库: 备份出来的文件可以用 XZ (linux 自带的压缩工具压缩). XZ压缩最新压缩率之王 xz这个压缩可能很多都很陌生,不过您 ...

  7. TimesTen数据库的备份和恢复

    建立不支持增量备份的全备份 做一个全备份,fileFull为不支持增量的全备份 $ ttbackup -type fileFull -dir /tmp/backupdir sampledb_1122( ...

  8. Linux系统下MySQL数据库的备份和恢复

    当我们MySQL数据库保存重要数据的时候,备份工作极为重要.本文介绍如何使用mysqldump备份和恢复数据,使用该方法,可以将数据库中的数据备份成一个文本文件,也可将备份好的数据库迁移到另一台的服务 ...

  9. MongoDB数据库的备份和恢复

    MongoDB数据库备份方式: 1.整库备份 2.单表备份 1.整库备份 备份整个数据库: mongodump -h 127.0.0.1:27000 -d park --authenticationD ...

随机推荐

  1. 踩坑事件:windows操作系统下的eclipse中编写SparkSQL不能从本地读取或者保存parquet文件

    这个大坑... .... 如题,在Windows的eclipse中编写SparkSQL代码时,编写如下代码时,一运行就抛出一堆空指针异常: // 首先还是创建SparkConf SparkConf c ...

  2. sql ce4 的问题

    前面用sql ce4来做数据库,发现一个问题.在localhos:xxx下面速度很快,但是一放到iis上面,速度变慢了.每个查询要13秒.分析了好久,最后,查找了半天的资料,去掉了数据库的密码.速度快 ...

  3. ffplay代码播放pcm数据

    摘抄雷兄 http://blog.csdn.net/leixiaohua1020/article/details/46890259 /** * 最简单的SDL2播放音频的例子(SDL2播放PCM) * ...

  4. WordPress 的 Google 字体问题解决办法

    在国内访问的时候,WordPress 里面引用的 google 字体可能会导致加载速度变得很慢. 要修改的地方有(我使用的版本是 4.0): wp-includes 里面的 script-loader ...

  5. ZeroMQ接口函数之 :zmq_getsockopt – 获取ZMQ socket的属性

    ZeroMQ API 目录 :http://www.cnblogs.com/fengbohello/p/4230135.html 本文地址 :http://www.cnblogs.com/fengbo ...

  6. Oracle总结

    摘自:http://www.cnblogs.com/linjiqin/category/283838.html oracle decode用法 select decode( x , 1 , ‘x is ...

  7. swif-自动引用计数

    import UIKit /* class Person { let name: String //强引用 init(name: String) { self.name = name print(&q ...

  8. Ubuntu下的PHP开发环境架设

    Ubuntu下的PHP开发环境架设   今天重新装了ubuntu那么就吧过程记录下. 打开终端,也就是命令提示符. 我们先来最小化组建安装,按照自己的需求一步一步装其他扩展.命令提示符输入如下命令: ...

  9. oracle分组取第一条

    SELECT * FROM (SELECT ROW_NUMBER() OVER(PARTITION BY x ORDER BY y DESC) rn,test1.* FROM test1) WHERE ...

  10. js正则匹配的一个日常应用

    应用实例 1 /** 将段落中的 \n 转换为 <p></p>, 规范存储 */ 2 function formatParagraphForStore(val) { 3 var ...