DB2-バックアップとリカバリー
この章では、データベースのバックアップと復元の方法について説明します。
前書き
バックアップとリカバリの方法は、情報を安全に保つように設計されています。バックアップおよびリカバリユーティリティを使用するコマンドラインインターフェイス(CLI)またはグラフィカルユーザーインターフェイス(GUI)では、DB2UDB内のデータベースのデータをバックアップまたは復元できます。
ロギング
ログファイルは、アプリケーションエラーからの回復に使用されるエラーログで構成されます。ログは、データベースの変更の記録を保持します。以下に説明するように、ロギングには2つのタイプがあります。
循環ログ
これは、新しいトランザクションログファイルを割り当てる必要があるときに古いトランザクションログを上書きして、ログファイルのシーケンスを消去して再利用する方法です。オフラインモードでは、完全バックアップのみを実行できます。つまり、完全バックアップを作成するには、データベースがオフラインである必要があります。
アーカイブロギング
このモードは、ロールフォワードリカバリと呼ばれるログファイルを使用したオンラインバックアップとデータベースリカバリをサポートします。logretainまたはuserexitをONに設定することにより、バックアップのモードを循環からアーカイブに変更できます。アーカイブ・ロギングの場合、バックアップ設定データベースには、DB2プロセス用に書き込み可能なディレクトリーが必要です。
バックアップ
使用する Backupコマンドを使用すると、データベース全体のコピーを取得できます。このバックアップコピーには、データベースシステムファイル、データファイル、ログファイル、制御情報などが含まれます。
オンラインだけでなくオフラインでもバックアップをとることができます。
オフラインバックアップ
Syntax: [アクティブなアプリケーション/データベースを一覧表示するには]
db2 list application
Output:
Auth Id Application Appl. Application Id
DB # of
Name Handle
Name Agents
-------- -------------- ---------- ---------------------
----------------------------------------- -------- -----
DB2INST1 db2bp 39
*LOCAL.db2inst1.140722043938
ONE 1
Syntax:[アプリを使用してアプリケーションを強制する。処理済みID]
db2 "force application (39)"
Output:
DB20000I The FORCE APPLICATION command completed
successfully.
DB21024I This command is asynchronous and may not
be effective immediately.
Syntax: [データベース接続を終了するには]
db2 terminate
Syntax: [データベースを非アクティブ化するには]
db2 deactivate database one
Syntax: 【バックアップファイルをとる】
db2 backup database <db_name> to <location>
Example:
db2 backup database one to /home/db2inst1/
Output:
Backup successful. The timestamp for this backup image is :
20140722105345
オンラインバックアップ
開始するには、モードをから変更する必要があります Circular logging に Archive Logging。
Syntax: [データベースが循環ログまたはアーカイブログを使用しているかどうかを確認するには]
db2 get db cfg for one | grep LOGARCH
Output:
First log archive method (LOGARCHMETH1) = OFF
Archive compression for logarchmeth1 (LOGARCHCOMPR1) = OFF
Options for logarchmeth1 (LOGARCHOPT1) =
Second log archive method (LOGARCHMETH2) = OFF
Archive compression for logarchmeth2 (LOGARCHCOMPR2) = OFF
Options for logarchmeth2 (LOGARCHOPT2) =
上記の出力で強調表示されている値は、オフモードの[logarchmeth1およびlogarchmeth2]です。これは、現在のデータベースが「CIRCULLARLOGGING」モードであることを意味します。'ARCHIVE LOGGING'モードで作業する必要がある場合は、構成ファイルに存在する変数logarchmeth1およびlogarchmeth2のパスを変更または追加する必要があります。
必要なアーカイブディレクトリでlogarchmeth1を更新する
Syntax: 【ディレクトリ作成】
mkdir backup
mkdir backup/ArchiveDest
Syntax: [フォルダのユーザー権限を提供するため]
chown db2inst1:db2iadm1 backup/ArchiveDest
Syntax: [構成LOGARCHMETH1を更新するには]
db2 update database configuration for one using LOGARCHMETH1
'DISK:/home/db2inst1/backup/ArchiveDest'
安全のためにオフラインバックアップを取り、データベースをアクティブ化して接続することができます。
Syntax: [オンラインバックアップを取るため]
db2 backup database one online to
/home/db2inst1/onlinebackup/ compress include logs
Output:
db2 backup database one online to
/home/db2inst1/onlinebackup/ compress include logs
次のコマンドを使用してバックアップファイルを確認します。
Syntax:
db2ckbkp <location/backup file>
Example:
db2ckbkp
/home/db2inst1/ONE.0.db2inst1.DBPART000.20140722112743.001
バックアップファイルの履歴の一覧表示
Syntax:
db2 list history backup all for one
Output:
List History File for one
Number of matching file entries = 4
Op Obj Timestamp+Sequence Type Dev Earliest Log Current Log
Backup ID
-- --- ------------------ ---- --- ------------ ------------
--------------
B D 20140722105345001 F D S0000000.LOG S0000000.LOG
------------------------------------------------------------
----------------
Contains 4 tablespace(s):
00001 SYSCATSPACE
00002 USERSPACE1
00003 SYSTOOLSPACE
00004 TS1
------------------------------------------------------------
----------------
Comment: DB2 BACKUP ONE OFFLINE
Start Time: 20140722105345
End Time: 20140722105347
Status: A
------------------------------------------------------------
----------------
EID: 3 Location: /home/db2inst1
Op Obj Timestamp+Sequence Type Dev Earliest Log Current Log
Backup ID
-- --- ------------------ ---- --- ------------ ------------
--------------
B D 20140722112239000 N S0000000.LOG S0000000.LOG
------------------------------------------------------------
-------------------------------------------------------------
-------------------------------
Comment: DB2 BACKUP ONE ONLINE
Start Time: 20140722112239
End Time: 20140722112240
Status: A
------------------------------------------------------------
----------------
EID: 4 Location:
SQLCA Information
sqlcaid : SQLCA sqlcabc: 136 sqlcode: -2413 sqlerrml: 0
sqlerrmc:
sqlerrp : sqlubIni
sqlerrd : (1) 0 (2) 0 (3) 0
(4) 0 (5) 0 (6) 0
sqlwarn : (1) (2) (3) (4) (5) (6)
(7) (8) (9) (10) (11)
sqlstate:
Op Obj Timestamp+Sequence Type Dev Earliest Log Current Log
Backup ID
-- --- ------------------ ---- --- ------------ ------------
--------------
B D 20140722112743001 F D S0000000.LOG S0000000.LOG
------------------------------------------------------------
----------------
Contains 4 tablespace(s):
00001 SYSCATSPACE
00002 USERSPACE1
00003 SYSTOOLSPACE
00004 TS1
-------------------------------------------------------------
----------------
Comment: DB2 BACKUP ONE OFFLINE
Start Time: 20140722112743
End Time: 20140722112743
Status: A
-------------------------------------------------------------
----------------
EID: 5 Location: /home/db2inst1
Op Obj Timestamp+Sequence Type Dev Earliest Log Current Log
Backup ID
-------------------------------------------------------------
----------------
R D 20140722114519001 F
20140722112743
------------------------------------------------------------
----------------
Contains 4 tablespace(s):
00001 SYSCATSPACE
00002 USERSPACE1
00003 SYSTOOLSPACE
00004 TS1
------------------------------------------------------------
----------------
Comment: RESTORE ONE WITH RF
Start Time: 20140722114519
End Time: 20140722115015
Status: A
------------------------------------------------------------
----------------
EID: 6 Location:
バックアップからのデータベースの復元
バックアップファイルからデータベースを復元するには、次の構文に従う必要があります。
Syntax:
db2 restore database <db_name> from <location>
taken at <timestamp>
Example:
db2 restore database one from /home/db2inst1/ taken at
20140722112743
Output:
SQL2523W Warning! Restoring to an existing database that is
different from
the database on the backup image, but have matching names.
The target database
will be overwritten by the backup version. The Roll-forward
recovery logs
associated with the target database will be deleted.
Do you want to continue ? (y/n) y
DB20000I The RESTORE DATABASE command completed successfully.
ディスクドライブに障害が発生する直前の最新の変更を含め、ログディレクトリにあるすべてのログをロールフォワードします。
Syntax:
db2 rollforward db <db_name> to end of logs and stop
Example:
db2 rollforward db one to end of logs and stop
Output:
Rollforward Status
Input database alias = one
Number of members have returned status = 1
Member ID = 0
Rollforward status = not pending
Next log file to be read =
Log files processed = S0000000.LOG -
S0000001.LOG
Last committed transaction = 2014-07-22-
06.00.33.000000 UTC
DB20000I The ROLLFORWARD command completed successfully.