DB2数据库中常用备份, 恢复命令以及DB2move的正确使用

数据库
此文章主要向大家讲述的是DB2数据库中常用备份, 恢复命令以及DB2move的正确使用,以下就是文章的主要内容的详细解析。

以下的文章主要向大家讲述的是DB2数据库中常用备份, 恢复命令以及DB2move的正确使用,以下就是对DB2数据库中常用备份, 恢复命令以及DB2move的正确使用的详细描述,望大家在浏览之后会对其有更深的了解。

DB2命令

DB2离线和在线全备、增量备份及恢复的操作步骤

1、离线全备份

1)、首先确保没有用户使用DB2:

 

  1. $DB2 list applications for db sample 

2)、停掉数据库并重新启动,以便断掉所有连接:

 

  1. DB2stop force  
  2. DB2start  

 

3)、执行备份命令:(使用TSM作为备份的介质)

 

  1. DB2 backup db sample use tsm 

备份成功,将会返回一个时间戳。

4)、检查备份成功:

DB2 list history backup all for sample ,可以看到多了这个备份的纪录。

DB2adutl query命令也可以看到返回值。

5)、备注:

首先对主节点(catalog表空间在的节点)执行备份命令,再对另外的节点也做这个操作。

2、 在线备份:

1)、首先打开一下支持在线备份的数据库配置参数:

DB2 update db cfg for sample using userexit on 启用用户出口

DB2 update db cfg for sample using logretain on 启用归档日志

DB2 update db cfg for sample using trackmod on 启用增量备份功能

(需要各个Node都分别做设置)

开启这些参数后,数据库处于backup pending状态,要求做数据库的离线全备份。做一下离线全备份,参考上面的命令。

2)、在线备份命令如下:

 

  1. DB2 backup db sample online use tsm 

备份成功,返回一个时间戳。

3)、同样可以用DB2数据库adutl 和DB2 list history察看备份纪录。

4)、备注:

同样,对每个节点都做这个操作。

3、 在线增量备份

1)、在开启了必须的三个参数的情况下,做增量备份:

 

  1. DB2 backup db sample online incremental use tsm 

备份成功,返回一个时间戳。

2)、同样可以用DB2adutl 和DB2 list history察看备份纪录。

3)、还有一种delta的备份:

 

  1. DB2 backup db sample online incremental delta use tsm 

这两种备份的区别,类似Oracle Exports的Incremental和Cumulative方式,DB2的incremental对应oracle的cumulative方式,而DB2的delta方式则对应oracle的incremental方式。

4)、备注:

同样,对每个节点都做这个操作。

4、 恢复数据库

1)、手工drop数据库,模拟灾难恢复的情况,执行如下操作:

 

  1. DB2 drop db sample 

2)、恢复备份历史纪录(每次backup,不论类型,都会备份历史纪录文件)。这里的时间戳应该是***的:

 

  1. DB2 restore db sample history file use tsm taken at 20030102223107 buffer 100 

3)、使用DB2的恢复帮助工具:

 

  1. DB2ckrst -d sample -t 20030101224424 -r database 

命令返回建议的必需的恢复操作命令。

4)、按照帮助工具的提示,先做版本恢复,恢复命令如下:

 

  1. DB2 restore db sample incremental use tsm taken at 20030101224424 buffer 100 

同样先做主节点的恢复,再做其他节点的恢复操作。

5)、这时数据库处于rollforward-pending state的状态,需要做roll forward 操作:

 

  1. DB2 rollforward db sample to 2003-01-12-13.27.25.000000 on all nodes and stop 

前滚到同一个时间点。这个操作要在主节点来做。

5、有关说明:

1)、恢复操作也有online和offline的,区别如同backup的操作。

2)、按照表空间的备份和恢复类似,加子句TABLESPACE ( tablespace-name )即可。表空间级别的备份/恢复操作要求数据库处于归档日志和启用增量备份模式下。

3)、恢复的例子中只做了版本恢复。若还有更新的全备份和增量备份的image,可以依次做恢复(注意使用DB2数据库ckrst的建议恢复次序和次数)后,再做roll forward.

 

  1. DB2 force applications all  
  2. DB2 backup db ldapDB2 to directory_or_device  

 

DB2 restore db ldapDB2 from directory_or_device replace existing其中 directory_or_device 是存储备份的目录或设备的名称。

 

  1. windows 迁移到 linux:  
  2. DB2move tfms export;  
  3. create db tfms;  
  4. DB2move tfms -u -p import > a.txt;  
  5. DB2move tfmsw179 import -u DB2admin -p DB2admin > a.txt  

 

确认执行:TERMINATE

6、恢复数据库

(1)先创建空数据库:DB2 create db NewdbName

(2)DB2 restore olddbName(需恢复数据库名称) taken at Times(时间点) into NewdbName(新数据库名称)

注:在恢复新的数据库的名称和刚创建的名称一样。

我自己的运用:

导出数据:

1:在DOS里运行DB2CMD

2:在D盘新建个文件夹CMS,在DB2CMD的DOS里CD到CMS目录

3:运行DB2move 要备份的数据库名称 export -u 用户名 -p 密码

4:成功

导出数据:

1:在DB2数据库控制台里建设一个空的数据库(缺省缓冲池和表空间大小设置大点***32K,代码集设置UTF-8)

2.首先在D盘选择一个文件夹例如cms

3:运行DB2move test import -u 用户名 -p 密码

【编辑推荐】

  1. import 或是 load多个DB2主从表谈何容易?
  2. DB2 V9.7启用索引压缩大揭秘
  3. DB2数据库备份参数修改后报错如何拯救?
  4. DB2卸载后正确巧妙恢复原来数据库中的某些数据
  5. 手动安装DB2数据库的实现在UNIX操作环境下
责任编辑:佚名 来源: 赛迪网
相关推荐

2010-08-12 11:26:03

2010-08-12 15:43:24

DB2数据库备份

2010-08-18 15:14:08

DB2恢复命令

2010-08-17 13:19:39

DB2数据库备份

2010-08-12 11:38:21

DB2数据库

2010-07-27 15:33:00

DB2数据库备份

2010-08-12 17:14:25

DB2备份恢复数据库步

2010-08-25 14:12:47

DB2备份恢复

2009-03-25 17:43:09

备份DB2IBM

2010-08-06 09:07:15

DB2线增量备份

2010-08-25 10:16:48

DB2备份Linux

2010-08-31 13:06:49

DB2数据库

2010-08-06 18:01:13

DB2数据备份

2010-08-17 09:11:42

DB2数据库备份性能

2011-03-03 14:52:40

DB2数据库恢复

2010-08-31 13:35:53

DB2备份恢复

2010-08-27 13:27:50

DB2备份恢复

2010-08-02 14:24:55

DB2数据库备份

2010-07-30 09:57:31

2010-08-17 15:06:50

DB2 多分区数据库备
点赞
收藏

51CTO技术栈公众号