Db2数据库的备份和恢复
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状态,此时连接数据库将会提示
此时可使用如下命令使数据库状态恢复正常
此时再执行连接数据库即可连接成功。