DATABASE AND TABLESPACE ROLLFORWARD
Database rollforward
The ROLLFORWARD command allows for point-in-time recovery, meaning that the command
will let you traverse the DB2 logs and redo or undo the operations recorded in the log up to a
specified point in time. Although you can roll forward your database or tablespace to any point in
time after the minimum point in time, there is no guarantee that the end time you choose to roll
forward will have all data in a consistent state.
Though the QUIESCE command is not discussed in this tutorial, it is worth mentioning that this
command can be used during regular database operations to set consistency points. By setting
these consistency points, you can always perform a point in time recovery to any of them and be
assured that your data is in synch.
Consistency points, along with a lot of other information, are recorded in the DB2 history file,
which can be reviewed with the LIST HISTORY command.
During the rollforward processing, DB2 will:
1. Look for the required log file in the current log path.
2. Reapply transactions from the log file if this log is found.
3. Search in the path specified by the OVERFLOW LOG PATH option and use the logs in
that location if the log file is not found in the current log path.
4. Use the method specified in LOGARCHMETH1 to retrieve the log file from the archive
path if the log file is not found in the current path and the OVERFLOW LOG PATH
option is not used.
5. Reapply the transactions, once the log is in the current log path or the OVERFLOW LOG
PATH.
SYSADM, SYSCTRL, or SYSMAINT authority is required to perform the ROLLFORWARD
command.
The syntax of the ROLLFORWARD command is:
ROLLFORWARD DATABASE database-alias [USER username
[USING password]]
[TO {isotime [ON ALL DBPARTITIONNUMS] [USING LOCAL
TIME | USING UTC TIME] |
END OF LOGS [On-DbPartitionNum-Clause]}] [AND
{COMPLETE | STOP}] |
{COMPLETE | STOP | CANCEL | QUERY STATUS [USING LOCAL
TIME | USING UTC TIME]}
[On-DbPartitionNum-Clause] [TABLESPACE ONLINE |
TABLESPACE (tblspace-name
[ {,tblspace-name} ... ]) [ONLINE]] [OVERFLOW LOG PATH
(log-directory
[{,log-directory ON DBPARTITIONNUM db-partitionnumber} ... ])] [NORETRIEVE]
[RECOVER DROPPED TABLE dropped-table-id TO exportdirectory]
On-DbPartitionNum-Clause:
ON {{DBPARTITIONNUM | DBPARTITIONNUMS} (dbpartition-number
[TO db-partition-number] , ... ) | ALL
DBPARTITIONNUMS [EXCEPT
{DBPARTITIONNUM | DBPARTITIONNUMS} (db-partitionnumber
[TO db-partition-number] , ...)]}
Let's look at an example. To perform a rollforward of the sample database, you can use any of
the following statements:
(1)ROLLFORWARD DATABASE sample TO END OF LOGS AND COMPLETE
(2)ROLLFORWARD DATABASE sample TO timestamp AND COMPLETE
(3)ROLLFORWARD DATABASE sample TO timestamp USING LOCAL TIME
AND COMPLETE
From the code above:
1. In this example, we'll roll forward to the end of the logs, which means that all archived
and active logs will be traversed. At the end, it will complete the rollforward and remove
the rollforward-pending state by rolling back any uncommitted transactions.
2. For this example, DB2 will roll forward to the specified point in time. The timestamp
used has to be in CUT (Coordinated Universal Time), which can be calculated by
subtracting the local time from the current time zone.
3. This example is similar to the previous one, but the timestamp can be expressed in local
time.
There is no keyword OFFLINE in the syntax, as this is the default mode. For the
ROLLFORWARD command, this is the only mode allowed for databases.
Tablespace rollforward
Tablespace rollforwards can generally be either online or offline. The exception is the system
catalog tablespace (SYSCATSPACE), which can only be rolled forward offline.
Here's an example tablespace rollforward:
ROLLFORWARD DATABASE sample
TO END OF LOGS AND COMPLETE
TABLESPACE ( userspace1 ) ONLINE
The options in this example were explained in the database rollforward section. The only new
thing here is the TABLESPACE option, which specifies the tablespace to be rolled forward.
Tablespace rollforward considerations
If the registry variable DB2_COLLECT_TS_REC_INFO is enabled, only the log files required
to recover the tablespace are processed. The ROLLFORWARD command will skip over log files
that are not required, which can speed up recovery time.
The QUERY STATUS option of the ROLLFORWARD command can be used to list the:
Log files that DB2 has rolled forward.
Next archive log file required.
Timestamp of the last committed transaction since rollforward processing began.
For example:
ROLLFORWARD DATABASE sample QUERY STATUS USING LOCAL
TIME
After a tablespace point in time rollforward operation completes, the tablespace is put in backuppending state. A backup of the tablespace or database must be taken because all updates made to
it between the point in time that the tablespace was recovered to and the current time have been
lost.
Database and tablespace rollforward
Performing rollforwards operations with the Control Center (Data Studio)
The figure below shows how to invoke the ROLLFORWARD command from the Control
Center. To perform a database or tablespace rollforward, right-click the database you want to roll
forward and select Roll-forward. We encourage you to try this on your own.
The following figure shows some options you need to complete to execute the ROLLFORWARD
command. We encourage you to try this on your own.
Review and examples
So far we've discussed the BACKUP, RESTORE, and ROLLFORWARD commands. The figures
below illustrate the different types of recovery that you should now understand.
For this scenario, circular logging is in effect:
At t6 there is an unscheduled power shutdown in your building. At t7, DB2 is restarted, and
when you connect to the database, crash recovery is started automatically (assuming db cfg
AUTORESTART is ON; otherwise you have to start it manually with a RESTART DATABASE
command). Crash recovery will traverse the active logs and will redo committed transactions. If
a transaction was not committed, it will be rolled back (undone). For this example, the two insert
statements will be redone and the delete statement will be undone.
For this scenario, circular logging is in effect:
At t7 you realize your data in all tablespaces has been corrupted by some transaction that started
at t6. At t8 you decide to restore from the full database backup taken at t1. Because circular
logging is in effect, many of the committed and externalized transactions in the logs have been
overwritten. Thus, logs cannot be applied (the ROLLFORWARD command cannot be run in
circular logging, so you cannot even roll forward active logs). Conclusion: Many of the good
transactions for t2 to t4 will be lost.
Review and examples
For this scenario, archival logging is in effect:
This is an extension of the previous scenario. In this case, the logs have been kept (archive logs);
after the full database restore is applied at t8, you can rollforward the logs at t9. Logs can be
rolled forward from t1 to any point in time, but likely you don't want to go past t6, when the bad
transaction started.
The following scenario reviews all these concepts in more detail.
1. An offline database backup finished at t1.
2. Daily transactions are performed at t2.
3. At t4 you realize one of the transactions has corrupted tablespace Z, and you stop this
transaction. Other transactions against other tablespaces continue.
4. Only for tablespace Z, you want the data at the state it was prior to t3 (prior to the start of
the bad transaction), thus:
o
At t5, you restore tablespace Z from the full offline backup taken at t1.
After the restore has finished, the tablespace will be left in rollforward pending
state.
At t6 you rollforward the tablespace up to t3, prior to the start of the bad
transaction.
You have just performed a point in time recovery. Because of this, DB2 will now
put the tablespace in backup pending state for consistency reasons.
At t7 you back up the tablespace. At this point, your database is consistent and all
users and applications can work normally. The restored tablespace will have a gap
from t3 to t7, which is what we intended -- to remove the corrupted data.
RECOVER DATABASE UTILITY
The recover database utility combines the RESTORE utility and the ROLLFORWARD utility in
one easy to use command. It performs the necessary restore and rollforward operations to
recover a database to a specified time, based on information found in the recovery history file. It
automatically selects the best suitable backup image to perform the recovery operations.
The syntax of the RECOVER DATABASE command is:
RECOVER DATABASE source-database-alias TO isotime
[USING LOCAL TIME]
[USER username [USING password]
[USING HISTORY FILE history-file]
[OVERFLOW LOG PATH directory]
[RESTART]
Examples
A SAMPLE database currently exists on your development server. A power failure last night has
damaged the database with data corruption. You need to recover the database as soon as possible.
You can do this by first locating the appropriate backup, then locating the required DB2 logs to
roll forward to a point in time just before the power failure. An easier way to recover the
SAMPLE database is to issue the RECOVER DB command, as follows:
(1) RECOVER DB sample
(2) RECOVER DB sample TO 2006-05-21-13.50.00 USING
LOCAL TIME
In line 1 above, DB2 recovers the SAMPLE database from the best available backup image, and
will rollforward to end of logs.
In line 2, DB2 recovers the SAMPLE database to a point in time, 2006-05-21-13.50.00, specified
in local time.
Recall that the RECOVER DATABASE utility relies on the database recovery history file to find
the best suitable backup image to restore. We did not specify the location of the history file in our
recover commands above. Because the SAMPLE database already exists on the server, DB2 is
able to locate the history file under the database directory path.
If the database to be recovered does not already exist, then the location of the history file must be
specified.
RECOVER DB sample TO END OF LOGS USING HISTORY FILE
(/home/user/oldfiles/db2rhist.asc)
A valid history file, containing the backup image and logs required, must exist on the server you
want to recover to. In our command above, if we did not have a copy of the history file (from file
transfer or history file backup) readily available, then we must somehow extract the history from
the backup image itself before we can run the RECOVER DATABASE command. In this case, it
might be easier to recover the database by running the standard RESTORE and ROLL
FORWARD commands sequentially.
If, for whatever reason, a recover operation is interrupted before it successfully completes, you
can restart it by rerunning the same command. If it was interrupted during the rollforward phase,
then recover utility will attempt to continue the previous recover operation without redoing the
restore phase. If you want to force the recover utility to redo the restore phase, issue the
RECOVER DATABASE command with the RESTART option to force the recover utility to
ignore any prior recover operation that failed to complete. If the recover utility was interrupted
during the restore phase, then it will start from the beginning.
The recover utility does not support the following RESTORE DATABASE command options:
TABLESPACE
tablespace-name
Table space restore operations are not supported.
INCREMENTAL
Incremental restore operations are not supported.
OPEN num-sessions
SESSIONS
You cannot indicate the number of I/O sessions that are to
be used with TSM or another vendor product.
BUFFER buffer-size
You cannot set the size of the buffer used for the restore
operation.
DLREPORT filename
You cannot specify a file name for reporting files that
become unlinked.
PARALLELISM n
You cannot indicate the degree of parallelism for the restore
operation.
WITHOUT
PROMPTING
You cannot specify that a restore operation is to run
unattended.
Database Rebuild
What is a database rebuild?
The database rebuild function is provided by the restore utility. It lets you rebuild a brand new
database using a set of backup images. You can choose to rebuild the entire database, or a
database with only a subset of tablespaces in the original database. The database rebuild
procedure depends on whether the database is recoverable or non-recoverable. We'll discuss both
scenarios in the following sections.
Rebuilding a recoverable database using tablespace backups
In the case of recoverable databases, the rebuild utility allows you to rebuild an entire database
using only tablespace backups. Full database backups are no longer required. Full database
backups may require larger maintenance windows, which are increasingly harder to schedule for
high availability shops. The ability to rebuild a database from table space backups is a great
enhancement for availability and recoverability.
Let's say you have a recoverable database called TEST. One night, there was a power failure. The
disk where the database was stored was damaged. The database is not accessible anymore, and
you want to recover the database. The database has the following tablespaces:
SYSCATSPACE (system catalogs)
USERSPACE1 (user data table space)
USERSPACE2 (user data table space)
USERSPACE3 (user data table space)
The following are available to you:
All the log files. Because the logs are stored on a separate disk from the database, they
were unharmed.
You do not have any database level backups, but you have the following tablespace
backups:
o
TEST.3.DB2.NODE0000.CATN0000.20060515135047.001 - Backup of
SYSCATSPACE and USERSPACE1
TEST.3.DB2.NODE0000.CATN0000.20060516135136.001 - Backup of
USERSPACE2 and USERSPACE3
TEST.3.DB2.NODE0000.CATN0000.20060517135208.001 - Backup of
USERSPACE3
If we were to use the restore and rollforward methods (discussed in the previous sections) to
recover the database to the most recent point in time, we would need to restore a database backup
and then rollforward the database to end of logs. Unfortunately, in this case, this is not possible
because we do not have a database backup. We only have tablespace backups. If we run a typical
RESTORE command on any of the tablespace backups, we would get the following error:
db2 restore db test taken at 20060517135208
SQL2560N The target database is not identical to the source database
for a restore
from a table space level backup.
With the database rebuild function, we now can rebuild the TEST database with only tablespace
backups and logs. To rebuild a database, specify the REBUILD option in the RESTORE
DATABASE command.
The following steps rebuild the TEST database to the most recent point in time.
1. Issue a RESTORE DATABASE command with the REBUILD option:
db2 restore db test rebuild with all tablespaces in
database taken at 20060517135208
2. The first step in a rebuild process is to identify the rebuild target image. The rebuild
target image should be the most recent backup image that you want to use in your rebuild
operation. It is known as the target image because it defines the structure of the database
to be rebuilt, including the table spaces that can be restored, the database configuration,
and the log sequence. It can be any type of backup (full, table space, incremental, online
or offline). In this example, the most recent backup image is
TEST.3.DB2.NODE0000.CATN0000.20060517135208.001; therefore we use it as the
target image of our rebuild operation.
3. After this command is executed successfully, the structure of the TEST database is
restored. We can get information such as the database configuration, and its history. If we
issue a LIST HISTORY command (for example, db2 list history all for test), click the
button to see what we will get as output
Op Obj Timestamp+Sequence Type Dev Earliest Log Current Log Backup ID
-- --- ------------------ ---- --- ------------ ------------ -------------R D 20060519121107001
F
20060517135208
--------------------------------------------------------------------------Contains 1 tablespace(s):
00001 USERSPACE3
--------------------------------------------------------------------------Comment: RESTORE TEST WITH RF
Start Time: 20060519121107
End Time: 20060519121108
Status: A
--------------------------------------------------------------------------EID: 7 Location:
Op Obj Timestamp+Sequence Type Dev Earliest Log Current Log Backup ID
-- --- ------------------ ---- --- ------------ ------------ -------------R P 20060519121108001
F
20060515135047
--------------------------------------------------------------------------Contains 2 tablespace(s):
00001 USERSPACE1
00002 SYSCATSPACE
--------------------------------------------------------------------------Comment: RESTORE TEST WITH RF
Start Time: 20060519121108
End Time: 20060519121113
Status: A
--------------------------------------------------------------------------EID: 8 Location:
Op Obj Timestamp+Sequence Type Dev Earliest Log Current Log Backup ID
-- --- ------------------ ---- --- ------------ ------------ -------------R P 20060519121113001
F
20060516135136
--------------------------------------------------------------------------Contains 1 tablespace(s):
00001 USERSPACE2
--------------------------------------------------------------------------Comment: RESTORE TEST WITH RF
Start Time: 20060519121113
End Time: 20060519121114
Status: A
--------------------------------------------------------------------------EID: 9 Location:
Op Obj Timestamp+Sequence Type Dev Earliest Log Current Log Backup ID
-- --- ------------------ ---- --- ------------ ------------ -------------R D 20060519121107
R
S0000001.LOG S0000003.LOG 20060518135208
--------------------------------------------------------------------------Contains 4 tablespace(s):
00001 USERSPACE3
00002 USERSPACE2
00003 USERSPACE1
00004 SYSCATSPACE
--------------------------------------------------------------------------Comment: REBUILD TEST WITH RF
Start Time: 20060519121107
End Time: 20060519121115
Status: A
--------------------------------------------------------------------------EID: 10 Location:
There are four entries in the LIST HISTORY command output shown above. They are all related
to the rebuild operation.
The first entry, EID: 7, indicates a restore operation on the backup image 20060517135208, and
the tablespace to be restored is USERSPACE3. (Recall that this backup image only contains
USERSPACE3.) However, we have asked to restore all tablespaces using the ALL
TABLESPACES option, so the rest of the tablespace in the database will also be restored. This is
reflected in the rest of the LIST HISTORY output.
Using the information in the backup history file, the restore utility finds the backup images of all
the tablespaces to be restored and restores them. After the restore, the tablespaces are placed in
roll-forward pending state. You can see the comment line in the LIST HISTORY output that each
tablespace is flagged with 'WITH RF', which indicates a rollforward is required following the
restore.
For the restore to work, all backup images must exist in the locations as stored in the history file.
Otherwise, an error is returned stating the restore utility cannot find a required image.
 Issue a ROLLFORWARD DATABASE command with the TO END OF LOGS option:
db2 rollforward db test to end of logs
After all tablespaces have been restored, they are put in rollforward pending state. We need to
rollforward the database to bring the database back to a normal state.
To rollforward a database during a rebuild operation, all log files for the time frame between the
earliest and most recent backup images must be available for the rollforward utility to use. If you
want to rollforward to a point in time more recent than the last backup, all the log files created
after the backup must also be available.
In our example, all logs are still in good shape and they are still in the log path specified by the
LOGPATH database configuration parameter. The rollforward utility will find them there. This is
why we did not need to specify the location of the logs files in the ROLLFORWARD command.
If the logs files had been stored somewhere else, then we must specify the location of the logs
files using the OVERFLOW LOG PATH option in the ROLLFORWARD command.
 Issue a ROLLFORWARD DATABASE command with the STOP option:
db2 rollforward db test stop
At this point the TEST database is connectable and all table spaces are in NORMAL state.
Rebuilding a recoverable database using only a subset of tablespace backups
As demonstrated by the previous example, the database rebuild functions let us rebuild an entire
database using only tablespace backups and logs. What makes this utility so robust is that we do
not need to have all tablespace backups to rebuild a database. We can rebuild a database with
only a subset of tablespace backups.
Let's reuse our last example, and say that the data in USERSPACE1 and USERSPACE2 are
really important to our users. We must restore these two tablespaces as soon as possible
following the power failure. Userspace3 is not as important and it is huge. If we restore all the
tablespaces, it's going to take a long time. It would be nice if we can rebuild a connectable
database with only USERSPACE1 and USERSPACE2 in it, so users can use the database right
away. When time permits, we can then restore USERSPACE3. The following steps show how
this can be done using the database rebuild utility.
1. Issue a RESTORE DATABASE command with the REBUILD option, specifying only a
subset of the tablespaces that you want restored:
db2 restore db test rebuild with tablespace
(SYSCATSPACE,USERSPACE1,USERSPACE2) taken
at 20060516135136
Although we only wanted to restore USERSPACE1 and USERSPACE2, we must restore
SYSCATSPACE as well, because this tablespace holds all the system information.
Without it, DB2 would not know anything about the structure of this database.
The target image we specified in the above command is the image that contains
USERSPACE2 and USERSPACE3. This is the most recent backup that contains the
tablespaces we want to restore. Although, image 20060517135208 is the latest backup of
the three, we cannot use it because it does not contain USERSPACE1, USERSPACE2, or
SYSCATSPACE.
The following command has the same effect:
db2 restore db test rebuild with all tablespaces in
database except tablespace
(USERSPACE3) taken at 20060516135136
Issue a ROLLFORWARD DATABASE command with the TO END OF LOGS option:
db2 rollforward db test to end of logs
2. Issue a ROLLFORWARD DATABASE command with the STOP option:
db2 rollforward db test stop
You may choose to rollforward to a point in time instead of end of logs. The point in time you
choose must be greater than the timestamp of the backup image you used in the restore.
Rebuilding a recoverable database using only a subset of tablespace backups
At this point, the TEST database is connectable and all tablespace are in NORMAL state except
USERSPACE3. USERSPACE3 is in RESTORE PENDING state.
You can restore USERSPACE3 at a later time, using a normal tablespace restore (without the
REBUILD option):
1. Issue a RESTORE DATABASE command and specify the tablespace to be restored:
db2 restore db test tablespace (USERSPACE3) taken at
20060517135208
2. Issue a ROLLFORWARD DATABASE command with the TO END OF LOGS option
and specify the tablespace to be rolled forward:
db2 rollforward db test to end of logs tablespace
(USERSPACE3)
3. Issue a ROLLFORWARD DATABASE command with the STOP option:
db2 rollforward db test stop
Now all four tablespaces of the TEST database are in NORMAL state.
Bringing only a subset of table spaces online is useful in a production environment, or in a
recovery situation like the above. It is also useful in a test environment, where you only need to
restore a subset of tablespaces for interested parties.
Rebuilding a recoverable database using only a subset of tablespace backups
Rebuilding a recoverable database using online backup images that contain log files
When rebuilding a recoverable database, you can use either database backups or tablespace
backups. The backups can also be either online or offline.
If you have an online backup image that contains log files, and you wish to use these logs to
rollforward the database, you can retrieve the logs from the image using the LOGTARGET
option of the RESTORE DATABASE command.
Let's reuse our TEST database as an example, and assume that the backup image
TEST.3.DB2.NODE0000.CATN0000.20060517135208.001 was an online backup image that
included logs. To recover the entire database using the tablespace backups and the logs that are
stored in the backup image:
1. Issue a RESTORE DATABASE command with the LOGTARGET option. During the
restore, the logs are extracted to the location specified by LOGTARGET.
db2 restore db test rebuild with all tablespaces in
database taken at 20060517135208
logtarget /logs
2. Issue a ROLLFORWARD DATABASE command with the TO END OF LOGS option
and specify the location of the logs:
db2 rollforward db test to end of logs overflow log
path (/logs)
3.
Note the OVERFLOW LOG PATH option is used to specify the log location.
4. Issue a ROLLFORWARD DATABASE command with the STOP option:
db2 rollforward db test stop
Rebuilding a recoverable database using incremental backup images
Incremental backup images can also be used to rebuild a database. When an incremental image is
involved in a rebuild process, by default the restore utility tries to use automatic incremental
restore for all incremental images. If you do not use the INCREMENTAL AUTOMATIC option
of the RESTORE DATABASE command, but the target image is an incremental backup image,
the restore utility will issue the rebuild operation using automatic incremental restore.
If the target image is not an incremental image, but another required image is an incremental
image, then the restore utility will also make sure those incremental images are restored using
automatic incremental restore. The restore utility will behave in the same way whether you
specify the INCREMENTAL AUTOMATIC options or not.
If you specify the INCREMENTAL option without the AUTOMATIC option, you will need to
perform the entire rebuild process manually. The restore utility will just restore the initial
metadata from the target image, as it would in a regular manual incremental restore. You will
then need to complete the restore of the target image using the required incremental restore
chain. Then you will need to restore the remaining images to rebuild the database. This process
can be cumbersome.
It is recommended that you use automatic incremental restore to rebuild your database. Only in
the event of a restore failure should you try to rebuild a database using manual methods.
Rebuilding a recoverable database using the redirect option
Since the rebuild functions are part of the restore utility, you can rebuild a database using the
redirect method, as in redirected restore. The following rebuilds the entire TEST database to the
most recent point in time using the REDIRECT option:
1. Issue a RESTORE DATABASE command with the REBUILD and REDIRECT option:
db2 restore db test rebuild with all tablespaces in
database taken at 20060517135208
redirect
2. Issue a SET TABLESPACE CONTAINERS command for each table space whose
containers you want to redefine. For example:
db2 set tablespace containers for 3 using (file
'/newuserspace2' 10000)
db2 set tablespace containers for 4 using (file
'/newuserspace3' 15000)
Database rebuild
Issue a RESTORE DATABASE command with the CONTINUE option:
1.
db2 restore db test continue
Issue a ROLLFORWARD DATABASE command with the TO END OF LOGS option. (This
assumes all logs are accessible in the logpath directory; otherwise, use the OVERFLOW LOG
PATH option to specify the alternate log path.)
1.
db2 rollforward db test to end of logs
Issue a ROLLFORWARD DATABASE command with the STOP option:
1.
db2 rollforward db test stop
At this point, the database is connectable and all table spaces are in NORMAL state.
Rebuilding a non-recoverable database
All rebuild methods we've discussed so far work for non-recoverable databases as well. The only
differences are:
If a database is non-recoverable, you can only use a database backup as the target image
in the rebuild operation, since tablespace backups are not available to non-recoverable
databases.
When the restore completes you can connect to the database right away -- no rollforward
operation is required. However, any table spaces not restored are put in drop pending
state, and they can no longer be recovered.
Database rebuild
Let's look at an example. Suppose we have a non-recoverable database MYDB. MYDB has three
tablespaces: SYSCATSPACE, USERSP1 and USERSP2. A full database backup was taken at
20060521130000.
To rebuild the database using only SYSCATSPACE and USERSP1:
db2 restore db mydb rebuild with tablespace
(SYSCATSPACE, USERSP1) taken at
20060521130000
Following the restore, the database is connectable. If you issue the LIST TABLESPACES
command you will see that the SYSCATSPACE and USERSP1 are in NORMAL state, while
USERSP2 is in DROP PENDING state. You can now work with the two table spaces that are in
NORMAL state.
If you want to take a database backup, you must first drop USERSP2 using the DROP
TABLESPACE command or the backup will fail.
Database rebuild restrictions
The ability to rebuild a database makes the restore utility more robust. However, there are a few
restrictions:
One of the table spaces you rebuild must be SYSCATSPACE.
You cannot perform a rebuild operation using the Control Center GUI tools. You must
either issue commands using the command line processor (CLP), or use the
corresponding application programming interfaces (APIs).
The REBUILD option cannot be used against a pre-Version 9.1 target image unless the
image is that of an offline database backup. If the target image is an offline database
backup, then only the table spaces in this image can be used for the rebuild. The database
will need to be migrated after the rebuild operation successfully completes. Attempts to
rebuild using any other type of pre-Version 9.1 target image will result in an error.
The REBUILD option cannot be issued against a target image from a different operating
system than the one being restored on unless the target image is a full database backup. If
the target image is a full database backup, then only the table spaces in this image can be
used for the rebuild.
Index re-creation
Rebuilding indexes
If a database crashes for some hardware or operating system reason, it is possible that some
indexes may be marked as invalid during the database restart phase. The configuration parameter
INDEXREC indicates when DB2 will attempt to rebuild invalid indexes.
INDEXREC is defined in both the database manager and database configuration files. There are
three possible settings for this parameter:
SYSTEM: This value can only be specified in the database configuration file. When
INDEXREC is set to this value, DB2 will look for the INDEXREC setting specified in
the database manager configuration file and use this value.
ACCESS: Invalid indexes are rebuilt when the index is first accessed.
RESTART: Invalid indexes are rebuilt during a database restart.
Summary
So that's the story on high availability backup and recovery. In this tutorial you learned:
Recovery concepts and the importance of having a recovery plan.
What a transaction (unit of work) is and how working with transactions ensures data
integrity.
The three types of recovery: crash, version, and rollforward.
You are now familiar with DB2 transaction logs concepts:
The log buffer
Primary and secondary logs
Active, online archive, and offline archive logs
Database configuration parameters: LOGPRIMARY, LOGSECOND, and LOGFILSIZ,
among others
The two types of logging: circular logging and archival logging (for which
LOGARCHMETH1 database configuration parameters must be enabled)
Infinite logging
Recoverable and. non-recoverable databases
You learned about database and tablespace backup concepts:
How to use the backup utility
Incremental and delta backups
How to invoke the BACKUP utility from the Control Center
The naming convention used for backup files
You learned about database and tablespace recovery concepts:
How to use the RESTORE utility
Minimum point in time
How to invoke the RESTORE utility from the Control Center
What the QUIESCE utility can do for you
What the history file contains
How to perform a redirected restore
You learned about database and tablespace rollforward concepts:
How to use the ROLLFORWARD utility
How to restore to a point in time using the ROLLFORWARD utility
How to invoke the ROLLFORWARD utility from the Control Center
How to use the RECOVER utility
How to rebuild a database using the RESTORE utility
Index re-creation and the INDEXREC configuration parameter